2014.8.8面试总结

一面:

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次,让想一种更好办法减小遍历次数

    提示过利用空格,每次直接翻转整个单词,但没答出来,网上找没找到更好的方法

你可能感兴趣的:(C++,面试,百度)