头条一面凉经

2019/3/25头条一面凉经
1:项目
2:Reactor模式是什么
3:线程和进程的区别,进程和线程哪些资源是共享的,哪些不是共享的,说具体的是什么资源?简单答了下进程的地址空间结构,啥的
4:malloc和new有什么区别 ,new的初始化什么时候做的?
5:内存碎片的概念  怎么避免内存碎片 ,答了下操作系统的内部和外部碎片。。
6:系统调用和cpu的调用(听了好多遍,貌似是这个)?
7:内核态和用户态有什么区别?
8:操作系统怎么调度线程的,有哪些线程调度算法?
9:epoll的边缘触发,然后我说到了状态变化才触发,然后又问什么状态发生变化?我说了数据由少变多,
然后问有1个字节,又来了1个字节,会触发么?我答是
10:什么叫IO多路复用,答了下事件驱动
11:什么叫非阻塞? 说了下非阻塞是等事件处理完,然后通知你,然后问怎么通知?我不知道自己说了啥?
我就瞎说下回调,怎么问怎么回调,然后我说了下epoll的回调,就绪链表什么的
12:做题
第一道:有一个数组,比如1 2 6 7 3 5 3
有一个数字可能出现多次,比如3,找出来
时间复杂度小于O(N^2),不能更改原数组,只能使用O(1)的空间
想了会,没做出来
第二道:层次遍历,奇数层逆置,很简单
然后凉了,自己还是要继续努力吧,太菜了

#字节跳动##面经##C++工程师##校招#
全部评论
跟链表判断是否有环类似,设置一个快指针和慢指针,慢指针每次走一步,快指针每次走两步,指针到数组尾部再重头开始,最后两个指针会指向重复的数。
点赞 回复 分享
发布于 2019-03-25 16:44
想问下第一道算法题应该怎么做..
点赞 回复 分享
发布于 2019-03-25 16:16
算法第一题可以问下元素有没有范围的,若是在0~n+1范围内的大小为n的数组,可以用二分查找的思想,先遍历看前半部分元素多还是后半部分元素多,然后不断缩小比较范围,这样到最后就可以锁定了,复杂度是O(nlogn).一般意义上的没想到,希望知道的能说一下
点赞 回复 分享
发布于 2019-03-25 16:19
你这是c语言嘛
点赞 回复 分享
发布于 2019-03-25 16:25
问了好多操作系统底层。。。。感觉都没接触过啊
点赞 回复 分享
发布于 2019-03-28 12:23
楼主是本科春招嘛?
点赞 回复 分享
发布于 2019-04-04 00:06
奇数层逆序打印吗
点赞 回复 分享
发布于 2019-12-01 19:57

相关推荐

河和静子:如果大专也能好过的话,我寒窗苦读几年的书不是白读了?
点赞 评论 收藏
分享
offer多多的六边形战士很无语:看了你的博客,感觉挺不错的,可以把你的访问量和粉丝数在简历里提一下,闪光点(仅个人意见)
点赞 评论 收藏
分享
5 38 评论
分享
牛客网
牛客企业服务