一面:
1.写出单链表逆转的代码
注意点:头结点用二级指针传参数,注意空链表和只有一个结点时的情况,尾结点逆转结束后改变头结点指针
2.写出求数组最小子序列的代码
剑指offer上最大子序列的变化型
核心思想是动态规划法:用D[j]表示以第j个元素为结尾的所有子序列中的最小值
D[j] = D[j-1] + data[j] ( j=0 或 D[j-1] <= 0 )
= data[j] ( j≠0 且 D[j-1] > 0 )
面试官还给了二种提示:
1.把所有数组元素取负数,这个问题就变成求最大子序列,再用书上的方法解决即可
2.另一种动态规划思路:开辟一个等长的数组P,P[j]存储原数组中从0到j所有元素之和,假如最小子序列区间是M~N,就应该令0~N之间的和尽可能小,0~M之间的和尽可能大,这样P[N]-P[M]的结果就越小。伪代码的表示是:min{ i,j∈[0,len-1] , j>i | P[j] - P[i] },复杂度为O(n2),不如上种方法好
3.多线程锁如何使用
4.TCP/IP协议三次握手机制
客户端:SYN( SQx )
服务端:ACK( SQx+1) + SYN( SQy)
客户端:ACK( SQy+1)
5.STL常见容器的作用,如何实现,是否看过源码
6.需要对数据进行频道的查找和读写时,用哪种STL合适?或者怎样组合用STL合适?
面试官提示后想到的方法是queue中存储Key,map中存储Key-Value,需要查找或读写时先在queue中找到Key的值,然后在map中选择对应的Value
7.是否用过gdb attach,inline函数能否加断点调试?
二面:
1.一个嵌入式系统假如只有16M内存,系统运行需要占8M,自己要跑个程序需要20M,怎么设计方案能使程序跑起来?
2.编译和链接的过程中都发生了什么事情,一堆.c文件最终是如何变成.exe的,makefile的编写
见http://blog.csdn.net/this_capslock/article/details/38660835
3.写出单词反转的代码
剑指offer原题,思路是先翻一次所有字符,再翻一次单词。
面试官分析后说这样会遍历4N次,内存交换2N次,让想一种更好办法减小遍历次数
提示过利用空格,每次直接翻转整个单词,但没答出来,网上找没找到更好的方法