字节跳动 后端开发实习生 二面面经 11.15

======11.19更新:帽子题第二问想出来啦!======
黑色,白色,红色帽子分别代表0,1,2。
第100个人把前99个人所有的数字加起来再模3,如果求得0就说黑色,1就说白色,2就说红色。假设这个数字为a。
第99个人同样的做法,将前98个相加后模3。假设这个数字为b。
计算(a-b+3)%3,求得的数字就是对应第99个人的帽子颜色。
第98个人计算前97个人的数字,再进行上述操作,以此类推直到第一个人。



===================原贴===================

11.15下午两点到三点进行的面试。
11.16中午接到HR电话说通过二面,约了11.19的面试。(本来是周三,后来面试官有事改到周五了)
又来攒人品啦~



(另外,问了一下面试官,字节面试一般是三轮技术面(mentor面、交叉面、leader面)和一轮HR面。

1. 自我介绍并询问
2. 重载、多态和继承
3. 多态如何实现?虚函数表简要介绍一下
4. 构造函数、析构函数可以是虚函数吗?为什么?
    构造函数:不行
    析构函数:行,且最好是虚函数,原因是:基类指针指向派生类对象时,如果基类析构函数不是虚函数,那么在delete时,派生类的析构函数不会被调用,会产生内存泄漏和异常。
    如:
#include <iostream>
using namespace std;
class Base
{
public:
    Base(){ cout<<"Constructing Base"<<endl;}
    ~Base(){ cout<<"Destroying Base"<<endl;}
};
 
class Derive: public Base
{
public:
    Derive(){ cout<<"Constructing Derive"<<endl;}
    ~Derive(){ cout<<"Destroying Derive"<<endl;}
 };
 
int main()
{
    Base *basePtr = new Derive();
    delete basePtr;
}
    输出为:
Constructing Base
Constructing Derive
Destroying Base
        而
#include <iostream>
using namespace std;
class Base
{
public:
    Base(){ cout<<"Constructing Base"<<endl;}
    virtual ~Base(){ cout<<"Destroying Base"<<endl;}//只有这里做了修改!!!
};
 
class Derive: public Base
{
public:
    Derive(){ cout<<"Constructing Derive"<<endl;}
    ~Derive(){ cout<<"Destroying Derive"<<endl;}
 };
 
int main()
{
    Base *basePtr = new Derive();
    delete basePtr;
}
    输出为:
Constructing Base
Constructing Derive
Destroying Derive
Destroying Base
5. 重载、重写
6. 计算机进程如何管理内存?虚拟地址和物理地址的转换在哪里发生?(MMU)
7. 异常和中断
8. 思维题:黑白帽子题
【问题1】100个人排成一队,每个人头上一顶帽子(黑or白),黑色和白色数量随机。每个人都能看到自己前面所有人的帽子颜色,但看不到自己帽子的颜色。从最后一个人开始往前说自己的帽子颜色,如果说对+1分,说错不扣分,问:怎样才能使得总分最高?总分最高是多少?
(奇偶校验码的思想。第100个人数一下前面99个人帽子颜色,若黑色是奇数,则说黑色,否则说白色。第99个人数一下前98个人帽子颜色,根据自己数的和第100个人说的推断出自己帽子颜色。以此类推直到第一个人,总分最高是99分。)
【追问】如果是黑色、白色、红色帽子呢?
(面试官提示是三进制、异或的思想,但我没想出来orz)
9. 代码题1:括号匹配判断
一个字符串中所有可能字符只有"(",")","[","]","{","}"。输入一个字符串,判断括号是否配对,输出“yes”或者“no”。
如:"(([[]])){}"则输出"yes","{[(])}"则输出"no"。
10.代码题2:输出所有可能的排列
给定两个数字n和m。有n组"()"括号,m组"{}"括号,输出所有匹配的字符串。如n=1,m=2,则输出:
(){}{}
(){{}}
({}{})
......
11. 反问

总结:
1. 面试字节一定要刷点力扣!!!
2. 我好傻(×

明天最后一面了,希望可以过。😭
大家也加油鸭!!!
#字节跳动实习##字节跳动##面试题目#
全部评论
楼主 最后一个代码题能贴个代码吗  还有就是 小括号为啥不能再大括号里面  哈哈哈
点赞 回复 分享
发布于 2021-12-04 10:11
希望楼主三面能过呀
点赞 回复 分享
发布于 2021-11-19 23:33
哈哈,三面怎么样呀
点赞 回复 分享
发布于 2021-11-19 16:06
98,从双色的思路出发,奇偶其实就是mod 2,用黑代表0,白代表1,红代表2,最后一个人计算前面黑色数量x,报出x mod 3,那么其他所有人都知道自己是不是黑色,回到双色问题
点赞 回复 分享
发布于 2021-11-19 12:42
什么部门呀
点赞 回复 分享
发布于 2021-11-19 10:11
帽子会了吗,想不明白
点赞 回复 分享
发布于 2021-11-19 01:04

相关推荐

不愿透露姓名的神秘牛友
06-21 11:33
昨天是学校最后一场招聘会,鼠鼠去参加了,全场只有一个招聘java的岗位,上来先做一份笔试题,做完后他拿张纸对答案,然后开始问简历上的问题,深圳小厂,6-8k(题目如下),后面还有两轮面试。然后我就在招聘现场逛呀逛,看到有公司招聘电商运营,给的比上年的小厂还多,鼠鼠就去了解了下,然后hr跟鼠鼠要了份简历,虽然我的简历上面全是求职Java开发相关的内容,但是hr还是鼓励我说没关系,她帮我把简历给老板看看,下周一会给我通知。招聘会结束后鼠鼠想了一段时间,也和朋友聊了聊,发现我可能是不太适合这个方向,然后就跟爸爸说回家了给我发条微信,我有些话想跟他说说。晚上爸爸到家了,跟我发了条微信,我立马跑出图书馆跟他打起了电话,这个通话长达一个小时,主要是跟爸爸坦白说我不想找这行了,是你的儿子太没用了,想试试其他行业。然后爸爸也跟我说了很多,说他从来没有希望我毕业后就赚大钱的想法,找不到就回家去,回家了再慢慢找,实在找不到就跟他干(帮别人装修房子,个体户),他也知道工作不好找,让我不要那么焦虑,然后就是聊一些家常琐事。对于后面的求职者呢我有点建议想提一下,就是如果招实习的时间或者秋招开始,而你的简历又很差的情况下,不要说等做好项目填充完简历之后再投,那样就太晚了,建议先把熟悉的项目写上简历,然后边投边面边完善,求职是一个人进步的过程,本来就比别人慢,等到一切都准备好后再投岂不是黄花菜都凉了。时间够的话还是建议敲一遍代码,因为那样能让你加深一下对项目的理解,上面那些说法只是针对时间不够的情况。当然,这些建议可能没啥用,因为我只是一个loser,这些全是建立在我理想的情况下,有没有用还需其他人现身说法。上篇帖子没想到学校被人认了出来,为了不丢脸只能匿名处理了。
KPLACE:找研发类或技术类,主要还是要1.多投 2.多做准备,很多方面都要做准备 3.要有心理准备,投累了就休息一两天,再继续,要相信自己能找到
投递58到家等公司10个岗位
点赞 评论 收藏
分享
Java大菜狗:纯纯招黑奴,一天还不到两百那么多要求,还不迟到早退,以为啥啊,给一点工资做一堆活,还以不拖欠员工工资为荣,这是什么值得骄傲的事情吗,纯纯***公司
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-24 12:26
点赞 评论 收藏
分享
评论
5
11
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务