腾讯的流程是一笔和四面。前三次面试都是技术面,hr面基本不刷人。笔试成绩决定面试顺序。技术面可能要写代码,做智力题目。
www.xtzrc.cn主要是c/c++、数据结构、操作系统等方面的基础知识。好像有sizeof、树等选择题。填空题是补充完整程序。附加题有写算法的、编程的、数据库sql语句查询的。还有一张开放性问题。
www.xtzrc.cn1.请定义一个宏,比较两个数a、b的大小,不能使用大于、小于、if语句。
www.xtzrc.cnint const shift = sizeof(int)*8-1;
www.xtzrc.cnunsigned mask = (0x1<
www.xtzrc.cnif ( (a-b)&mask )
www.xtzrc.cnmax_num = b;
www.xtzrc.cnelse
www.xtzrc.cnmax_num = a;
www.xtzrc.cn#define Max(a,b) ( a/b)?a:b
www.xtzrc.cn2.如何输出源文件的标题和目前执行行的行数
www.xtzrc.cnint line= __LINE__;
www.xtzrc.cnchar *file = __FILE__;
www.xtzrc.cncout<<"file name is "<<(file)<<",line is "<
www.xtzrc.cn3.两个数相乘,小数点后位数没有限制,请写一个高精度算法与大数相乘原理一样,只是调整小数点位置,即有效小数个数
www.xtzrc.cn算法提示:
www.xtzrc.cn输入 string a, string b;计算string c=a*b; 返回 c;
www.xtzrc.cn1, 纪录小数点在a,b中的位置l1,l2,则需要小数点后移动位置数为l=length(a)+length(b)-l1-l2-2;
www.xtzrc.cn2, 去掉a,b中的小数点,
www.xtzrc.cn(a,b小数点后移,使a,b变为整数)
www.xtzrc.cn3, 计算c=a*b;
www.xtzrc.cn(要么用java的BigInterger搞, 要么自己用C++写高精度数乘法,超过百万位,用FFT,我就不细说,这都预先写过就别做了
www.xtzrc.cn)
www.xtzrc.cn4, 输出c
www.xtzrc.cn(注意在输出倒数第l个数时,输出一个小数点。若是输出的数少于l个,就补0)
www.xtzrc.cn4.写一个病毒
www.xtzrc.cnwhile (1)
www.xtzrc.cn{
www.xtzrc.cnint *p = new int[10000000];
www.xtzrc.cn}
www.xtzrc.cn上面这个不对,没有传染性,寄生性……
www.xtzrc.cn5.不使用额外空间,将 A,B两链表的元素交叉归并将树序列化转存在数组或 链表中
www.xtzrc.cnstruct st{
www.xtzrc.cnint i;
www.xtzrc.cnshort s;
www.xtzrc.cnchar c;
www.xtzrc.cn};
www.xtzrc.cnsizeof(struct st);
www.xtzrc.cn8
www.xtzrc.cnchar * p1;
www.xtzrc.cnvoid * p2;
www.xtzrc.cnint p3;
www.xtzrc.cnchar p4[10];
www.xtzrc.cnsizeof(p1www.xtzrc.cn.p4) =?
www.xtzrc.cn4,4,4,10
www.xtzrc.cn5.让你在100000000个浮点数中找出最大的10000个,要求时间复杂度优。
www.xtzrc.cn最小堆
www.xtzrc.cn二分查找
www.xtzrc.cn快速排序
www.xtzrc.cn双向链表的删除结点
www.xtzrc.cn6、有A、B、C、D四个人,要在夜里过一座桥。他们通过这座桥分别需要耗时1、2、5、10分钟,只有一支手电,并且同时最多只能两个人一起过桥。请问,如何安排,能够在17分钟内这四个人都过桥?
www.xtzrc.cn基础题有15道选择和2道读程序填空。选择题的确是很基础,主要考数据结构,还有一些体系结构、数据库的题目;读程序题跟我们平时考试的差不多,一道是两个升序链合并成一个升序链+递归,一道是四色着色方案附加题有几道没有看清楚。有一道是unix防僵死算法,最后一道是sql查询,还有几道忘了,其中一个是很长的程序题。
www.xtzrc.cnwww.xtzrc.cn