学者谷

位置:首页 > 职场范文 > 笔试

腾讯笔试题(一、二)

笔试2.37W

腾讯笔试题(一)

腾讯笔试题(一、二)

腾讯的流程是一笔和四面。前三次面试都是技术面,hr面基本不刷人。笔试成绩决定面试顺序。技术面可能要写代码,做智力题目。

主要是c/c++、数据结构、操作系统等方面的基础知识。好像有sizeof、树等选择题。填空题是补充完整程序。附加题有写算法的、编程的、数据库sql语句查询的。还有一张开放性问题。

1.请定义一个宏,比较两个数a、b的大小,不能使用大于、小于、if语句。

int const shift = sizeof(int)*8-1;

unsigned mask = (0x1

max_num = b;

else

max_num = a;

#define Max(a,b) ( a/b)?a:b

2.如何输出源文件的标题和目前执行行的行数

int line= __LINE__;

char *file = __FILE__;

cout<<"file name is "<<(file)<<",line is "< 3.两个数相乘,小数点后位数没有限制,请写一个高精度算法与大数相乘原理一样,只是调整小数点位置,即有效小数个数

算法提示:

输入 string a, string b;计算string c=a*b; 返回 c;

1,纪录小数点在a,b中的位置l1,l2,则需要小数点后移动位置数为l=length(a)+length(b)-l1-l2-2;

2, 去掉a,b中的小数点,

(a,b小数点后移,使a,b变为整数)

3,计算c=a*b;

(要么用java的BigInterger搞, 要么自己用C++写高精度数乘法,超过百万位,用FFT,我就不细说,这都预先写过就别做了

)

4,输出c

(注意在输出倒数第l个数时,输出一个小数点。若是输出的数少于l个,就补0)

4.写一个病毒

while (1)

{

int *p = new int[10000000];

}

上面这个不对,没有传染性,寄生性……

5.不使用额外空间,将 A,B两链表的元素交叉归并将树序列化转存在数组或 链表中

struct st{

int i;

short s;

char c;

};

sizeof(struct st);

8

char * p1;

void * p2;

int p3;

char p4[10];

sizeof(p1...p4) =?

4,4,4,10

5.让你在100000000个浮点数中找出最大的10000个,要求时间复杂度优。

最小堆

二分查找

快速排序

双向链表的'删除结点

6、有A、B、C、D四个人,要在夜里过一座桥。他们通过这座桥分别需要耗时1、2、5、10分钟,只有一支手电,并且同时最多只能两个人一起过桥。请问,如何安排,能够在17分钟内这四个人都过桥?

基础题有15道选择和2道读程序填空。选择题的确是很基础,主要考数据结构,还有一些体系结构、数据库的题目;读程序题跟我们平时考试的差不多,一道是两个升序链合并成一个升序链+递归,一道是四色着色方案附加题有几道没有看清楚。有一道是unix防僵死算法,最后一道是sql查询,还有几道忘了,其中一个是很长的程序题。

发信人: charly (查理一世), 板面: Work

标 题: 腾讯笔试题

发信站: 飘渺水云间 (Sat Nov 11 10:55:33 2006), 转信

15个选择题,60分

一个程序填空,40分

三道附加题60分

附加题考的是

1、不用第三个变量实现两个整形变量的交换linux的子进程操作系统资源抢占管理,两个进程要对文件进行独占访问,采用共享变量,判断可行否

2、书写strcpy()

时间两个小时,选择题 15*4

然后是程序填空题 10 (2*5), 30 (10*3)

附加题用c++ 实现一个链地址hash。

程序填空题我就不说了,比较easy的说,值得一提的是选择题。

绝大部分考的是C++,我大致说下主要部分吧:

涉及程序执行压栈的: 1道

涉及容器和迭代器的: 4道

涉及虚拟函数以及dynamic_cast的 3道

涉及参数传递的 1道

简单的程序段落判断 2道

涉及类的静态成员赋值的 1道

剩下的是杂七杂八的。不管怎么说,假如你把c++ primer 仔细阅读了一遍,基本上没问题。考的有些细,没有涉及算法和编译等知识,所以我同屋一个兄弟很郁闷,因为他linux底层比较好,本来报的是后台开发,哪知道结果考这种类型的题目。程序填空的考了文件操作,以及数组移动等。附加题比较简单的说,只要把数据结构的hash部分好好看,然后用class组装一下就ok了。

最后祝大家好运,今年腾讯计划50%的是校园招聘,感觉很不多

腾讯笔试题(二)

一些腾讯笔试题及其答案

声明:题目来自网络,答案大部分来自网络并经过整理;有些是自己查资料和请教他人得来的。

1.1、有A、B、C、D四个人,要在夜里过一座桥。

他们通过这座桥分别需要耗时1、2、5、10分钟,只有一支手电,并且同时最多只能两个人一起过桥。

请问,如何安排,能够在17分钟内这四个人都过桥?

答案:A & B -->2 mins

1 mins <-- A

C & D -->10 mins

2 mins <-- B

A & B --> 2 mins

一共 2 + 1 + 10 + 2 + 2 = 17 mins

1.2 、1-20的两个数把和告诉A,积告诉B,A说不知道是多少,

B也说不知道,这时A说我知道了,B接着说我也知道了,问这两个数是多少?

答案:2和3

答案有3个:

1 2和2

2 2和3

3 2和4

第一个大概是(2,2)吧

A得到的是2+2=4,B得到的是2*2=4

开始A当然不知道,因为有可能是(2,2)或(1,3)

这时B也不知道,因为有可能是(2,2)或(1,4),而且这两种情况A无均会答"不知道"

这时,我就已经知道了,因为如果是(1,3),B得到的是3,只有(1,3)这种情况,就不会回答"不知道"

由B的答案,A可以肯定是(2,2)

同样,A说"知道"了以后,B也就知道了

因为如果是(1,4),A得到的是5,只凭第二步B说"不知道",A不可能在第三步便"知道"

所以B可以断定,是(2,2)

逻辑推理:这两个数是多少?

两个人A,B。数字为2-100之间的自然数。现找出两个数,把其和告诉A,把其积告诉B。然后问A知道不知道是哪两个数,A说:“虽然我

不知道,但是肯定B也不知道。” 再问B,B说:“本来我不知道,但是听到A说这句话,现在我知道了。”,A听到B说他知道了,然后就说:

“现在我也知道了”。那么这两个数是多少呢?

由A说:“虽然我不知道,但是肯定B也不知道。”得:和不是两个素数的和

得出以下数字:

11,17,23,27,29,35,37,41,47,51,53,57,59。。。。。等

通过以上列出的和,推出积的可能性:

和-》积

11-》18,24,28,30

17-》30,42,52,60,66,70,72

23-》42,60,76,90,102,112,120

27-》50,72,92,110,126,140,152。。。。

29-》54,78,100,120,115,138,154。。。。

35-》66,96,124,150,174,196。。。。

根据“B说:“本来我不知道,但是听到A说这句话,现在我知道了。” ”我们首先可以删除一些重复出现的积,如30,120

得到:

11-》18,24,28,

17-》52,

23-》42,76,

27-》50,92。。。

29-》54,78。。。。

35-》96,124。。。

由“A对B说:呵呵,我也知道了。”可以知道积是唯一的,那只有52了

所以得到和是17,积是52

答案就是4和13。

1.3 、爸爸,妈妈,妹妹,小强,至少两个人同一生肖的概率是多少?

1-12*11*10*9/12*12*12*12 = 1-55/96 = 41/96

1.4 某人去玩具店买小熊,单价30元. 付给玩具店老板100元玩具店老板没零钱,

去水果店换了100元零钱回来找给那人70元. 那人走后, 水果店老板找到玩具店老板说刚才的100元是假币,

玩具店老板赔偿了水果店老板100元

问:玩具店老板损失了多少钱?

答案: 70+小熊的进价

2 请定义一个宏,比较两个数a、b的大小,不能使用大于、小于、if语句

答案:

#define max(a,b) ((((long)((a)-(b)))&0x80000000)?b:a)

若a > b ,则a-b的二进制最高位为0,与上任何数还是0,所以大数为a;

否则,a-b为负数,二进制最高位为1,与上0x80000000(最高位为1其他为0)之后为1,所以此时的大数为b.

3 计算 a^b << 2

答案:

运算符优先级:括号,下标,->和.(成员)最高;

单目的比双目的高;

算术双目的比其他双目的高;

位运算 高于 关系运算;

关系运算 高于 按位运算(与,或,异或);

按位运算 高于 逻辑运算;

三目的只有一个 条件运算,低于逻辑运算;

赋值运算仅比 , (顺序运算)高。

在此题中,位左移"<<" 优先级高于按位异或"^",所以b先左移两位(相当于乘以4),再与a异或。

例如: 当 a = 6; b = 4 时; 则 a^b<<2 = 22

4、如何输出源文件的标题和目前执行行的行数?

答案: printf("The file name: %dn", __FILE__);

printf("The current line No:%dn", __LINE__);

ANSI C标准预定义宏:

__LINE__

__FILE__

__DATE__

__TIME__

__STDC__ 当要求程序严格遵循ANSI C标准时该标识符被赋值为1

__cplusplus__ 当编写C++程序时该标识符被定义

5、 a[3][4]哪个不能表示 a[1][1]: *(&a[0][0]+5) *(*(a+1)+1) *(&a[1]+1) *(&a[0][0]+4)

答案: *(*(a+1)+1)

a是数组的首地址,a+1相当于&a[0][1], *(a+1)=a[0][1],则*(*(a+1)+1)= *(a[0][1] + 1) =/= a[1][1]

6、 fun((exp1,exp2),(exp3,exp4,exp5))有几个实参?

答案:两个。

形式参数:在声明和定义函数时,写在函数名后的括号中的参数。

实参是调用参数中的变量,行参是被调用函数中的变量。

7、 希尔 冒泡 快速 插入 哪个平均速度最快?

答案:快速排序

快速排序、归并排序

标签:笔试 腾讯