2014年3月阿里巴巴实习生招聘笔试题目-北京站

22 篇文章 0 订阅
18 篇文章 0 订阅

一、单选题(前10题,每题2分;后10题,每题3分;共50分。选对得满分,选错倒扣1分,不选得0分)

 

1.假设一个主机的IP地址为192.168.5.121,而子网掩码为255.255.255.248。那么该主机的网络号部分(包括子网号部分)为      

A. 192.168.5.12      B. 192.168.5.121    C. 192.168.5.120    D.192.168.5.32

答案:C

IP地址 & 子网掩码 = 网段号

题目中IP地址=192.168.5.121,对应二进制为11000000.10101000.00000101.01111001

子网掩码=255.255.255.248,对应二进制为   11111111.11111111.11111111.11111000

掩码前24都是1,按位与的结果不变,最后8位与运算后结果为01111000,对应十进制为120,所以选C


2.64位系统上,定义变量int*a[2][3]占据     字节。

A.4    B.12    C. 24    D.48

答案:D

int* a[2][3]的含义:a是一个数组,共有2*3=6个元素,每个元素存储一个int类型的指针

在64位系统下,所有指针的长度都是64位,即8字节,所以共占据8*6=48字节

在32位系统下,所有指针的长度都是32位,即4字节,两者的不同是由于寻址空间扩充了。


3.Linux中使用df –h/home和du –sh/home所查看到的已使用的磁盘容量不同,可能的原因是       

A.命令不同,所以结果肯定不同      B.两个命令所用的参数有问题

C.运行中的进程打开文件被删除导致   D. Linux的特性导致的

答案:D

du -sh命令通过将指定文件系统中所有的目录、符号链接和文件使用的块数累加得到该文件系统使用的总块数;
df命令通过查看文件系统磁盘块分配图得出总块数与剩余块数。
文件系统分配其中的一些磁盘块用来记录它自身的一些数据,如i节点,磁盘分布图,间接块,超级块等。
这些数据对大多数用户级的程序来说是不可见的,通常称为Meta Data。
du命令是用户级的程序,它不考虑Meta Data,
df命令则查看文件系统的磁盘分配图并考虑Meta Data。
因此正常情况下,
df计算的USED空间会比du计算的结果要稍大


4.一个C语言程序在一台32位及其上运行。程序中定义了三个变量xyz,其中x和z是int型,y为short型。当x=127,y=-9时,执行赋值语句z=x+y后,xyz的值分别是    

A. x=0000007FH, y=FFF9H, z=00000076H

B. x=0000007FH, y=FFF9H, z=FFFF0076H

C. x=0000007FH, y=FFF7H, z=FFFF0076H

D. x=0000007FH, y=FFF7H, z=00000076H

答案:D

在32位系统上,int占4字节,short占2字节

对于x=127,直接按照原码来存,即0000007F

对于y=-9,其值为负数,按照补码来存储,负数补码计算方法是原码除符号位外,其它按位取反再加1:-9的原码表示为1000 0000 0000 1001,反码为1111 1111 1111 0110,再加上1的结果为1111 1111 1111 0111,即FFF7

对于z=x+y,是short型和int型的加法,中间会有short向int的隐式类型转换,即由16位扩充至32位。扩充时的规则是:低位保持不变,如果是正数则高位全补0,如果是负数则高位全补1。将-9即FFF7扩充为int时,在高16位都补上1,结果为FFFFFFF7,再做加法运算,结果为0000007F+FFFFFFF7=00000076(最高位溢出)

 

5.有如下数组定义,

int [][] myArray = new int [3][] { new int[3]{5,6, 2},

new int[5]{6, 9, 7, 8, 3},

new int[2]{3,2}};

则,myArray[2][2]的值是         

A. 9        B. 2       C.6        D.越界

答案:D

myArray这样的定义方法在机器上无论用JAVA还是C++都无法通过编译,不知道是啥原因。

从题意上看,myArray[2][2]实际上是取二维数据第3行3列的元素,该元素不存在,所以越界。

 

6.快速排序的期望运行时间复杂度是         

A. O(n2)    B. O(nlogn)    C. O(n)    D.O(2n)

答案:B

快速排序是一种排序算法,对包含n个数的输入数组,平均时间为O(nlogn),最坏情况是O(n2)

 

7.在一个长度为n的顺序表中删除第i个元素,要移动     个元素。如果在第i个元素前插入一个元素,要后移      个元素。

A. n-i, n-i+1    B. n-i+1, n-i    C. n-i, n-i    D. n-i+1, n-i+1

答案:A

删除第i个元素,需要把其后从第i+1至第n个元素都往前移一位,需要移动 n - (i+1) + 1 =n-i个元素

在第i个元素前插入,需要把从第i至第n个元素都往后移一位,需要移动n-i+1个元素


8.下面C++程序的输出是       

void f(char *x)

{

         x++;

         *x= ‘a’;

}

int main()

{

         charstr [ sizeof (“hello”)];

         strcpy(str, “hello”);

         f(str);

         cout<< str;

         return0;

}

A. hello    B. hallo     C. allo    D.以上都不是

答案:B

执行到函数f(str)后进入子函数,此时*x="hello"

执行完x++后,*x="ello"

执行完*x='a'后,*x="allo"

子函数采用地址传递参数,结束后指针指向的内容被改变,但指针本身仍是值传递,子函数内部的x++对外界的str没有影响

因此str仍指向'h'处,结果为hallo


9.有以下程序,其执行结果是      。

char fun(char x, char y)

{

         if(x)   return y;

}

int main()

{

         inta = ‘0’, b = ‘1’, c = ‘2’;

         printf(“%c\n”,fun(fun(a, b), fun(b, c)));

}

A.函数调用出错    B.2    C.0    D.1

答案:B

注意'0'是一个字符,不是数字0,int a='0'的结果是把'0'的ASCII码值赋给a

所以fun(fun(a, b), fun(b, c)) = fun( '1' , '2' ) = '2'

 

10.当n=6时,下列函数的返回值是        

int foo (int n)

{

         if(n<= 2)    return n;

return foo(n-1)+ foo(n-2);

}

A.1    B. 8    C. 13    D.21

答案:C

其实就是斐波纳契数列,递归算一下就OK了

f(6) = f(5) + f(4)

      = f(4) + f(3) + f(3) + f(2) = f(4) +2f(3) + f(2)

      = f(3) + f(2) + 2f(2) + 2f(1) + f(2)

      = f(2) + f(1) + f(2) + 2f(2) + 2f(1) + f(2)

      = 5f(2) +3f(1) = 5*2 + 3*1 = 13

 

(以下每题3分)

11.在一台主流配置的PC机上,调用f(35)所用的时间大概是       

int f(int x)

{

int s = 0;

while(x-->0) s+=f(x);

return max(s, 1);

}

A. 几毫秒     B. 几秒     C.几分钟      D.几小时

答案:C

我在自己机器上测试大概要跑10分钟左右,其它同学也试了试,最快的大概3分钟,慢的有50分钟的,因此可以确定选C

后来想想可以这么分析:f(35)一共递归调用函数f 2^35次,具体推导只能一次一次算了,f(x)相当于把前面从f(0)到f(x-1)的结果累加起来

主流配置的PC机CPU主频按2GHz来算,即一秒钟执行2*10^9次指令

设函数f 转成机器语言后共有n条指令,那么f(35)的运行时间可以表示为2^35*n/(2*10^9)≈17n秒,n这个值虽然不知道,但函数f对应的指定数肯定不止4条,所以17n>60,应该是分钟级别了

 

12.在一棵度为4的树T中,有20个度为4的节点,10个度为3的节点,1个度为2的节点,10个度为1的节点,则树T的叶子个数为      

A.41    B. 82    C. 113    D.122

答案:B

在树中,总度数 = 总结点数 - 1

对应本题,总度数=20*4+10*3+1*2+10*1=122,

总结点数=20+10+1+10+n(叶子结点)

即41+n-1 = 122 , n = 82

 

13.有堆栈S,按顺序ABCD进栈,则出栈顺序不可能存在的是       

A. DCBA        B. BACD     C. BADC       D. CABD

答案:D

A:A进,B进,C进,D进,D出,C出,B出,A出

B:A进,B进,B出,A出,C进,C出,D进,D出

C:A进,B进,B出,A出,C进,D进,D出,C出

D:出C后不能紧接着再出A


14. 使用二分查找在有序数组a[n]中查找一个元素x的时间复杂度        

A. O(n)    B. O(n2)    C. O(log n)    D. O(n logn)

答案:C

二分查找法充分利用了元素间的次序关系,采用分治策略,可在最坏的情况下用O(log n)完成搜索任务

可等价想像成二叉排序树,搜索到最底层节点,需要搜索log n次


15. 图中标出了每条有向公路最大流量,请问从S到T最大流量是      


A.46    B. 47    C. 54    D.77

答案:A


 

16. 一天,有为年轻人来到张老板的店里花80元买了件原价为160元的纪念品。这件礼物的成本是65元。结账时,年轻人掏出一张100元,张老板当时没有零钱,就用那100元向隔壁店家换了零钱,找给年轻人20元。但是隔壁店家后来发现那100元是假钞,张老板无奈还了100元。那么,张老板在这次交易中实际损失了      元钱。

A. 65    B. 85    C. 100    D.185

答案:B


 

17. 2^100 mod 7 =         

A. 2    B. 3    C. 4    D.5

答案:A

数论的知识,23 mod 7 = 8 mod 7 = 1

所以2100 mod 7 = (23)33 * 2 mod 7 = 2 mod 7 = 2


 

18. 某公司在华东和华南两大区域开展业务,年底汇总业绩的时候发现,两大区域的月度客户转化率(=成为会员的客户数/访问店铺的客户数)分别提高了10%和5%,以下描述中正确的是      

A.尽管各自的月度转化率都有提高,但公司的整体月度转化率仍有可能降低

B.市场对业务认可度提高,越来越多访问店铺的客户成为会员

C.华东区的客户更容易被转化,该公司应该把业务重点放在这个区域

D.华南区的客户更需要提高转化,该公司应该把业务重点放在这个区域

 

19. 一次有8个人参加的网球比赛,根据选手的实力,分别编号为1至8,1号最强,8号最弱,而实力差距小于等于2才有可能出现爆冷。8人进行1/4决赛,胜出的4人继续半决赛,直到冠军产生,问有可能获得冠军的编号最大的选手是    

A. 4    B. 6     C. 7    D. 8

 

20. 某国家非常重男轻女,若一户人家生了一个女孩,便再要一个,直到生下男孩为止,假设生男生女概率相等,请问平均每户人家有       个女孩。

A. 0.5    B. 2/3     C. 1      D. 4/3

 

二、不定向选择(4题,每题5分,每题有1-5个正确选项,完全正确计5分,漏选记2分,不选记0分,多选、错选记-2分)

21. 以下有关C语言的说法中,错误的是       

A.内存泄露一般是只程序申请了一块内存,使用完后,没有及时将这块内存释放,从而导致程序占用大量内存。

B.无法通过malloc(size_t)函数调用申请超过该机器物理内存大小的内存块。

C. 无法通过内存释放函数free(void *)直接将某块已经使用完的物理内存直接归还给操作系统

D. 可以通过内存分配函数malloc(size_t)直接申请物理内存。

 

22.下面关于二叉搜索树正确的说法包括         

A.待删除节点有左子树和右子树,只能使用左子树的最大值节点替换待删除节点

B. 给定一棵二叉搜索树的前序和后序遍历结果,无法确定这棵二叉搜索树

C. 给定一棵二叉搜索树,根据节点值大小排序所需时间复杂度是线性的

D. 给定一棵二叉搜索树,可以在线性时间复杂度内转化为平衡二叉搜索树

 

23. 被称为中国与人的周玮,仅仅使用1分钟的时间就可以对16位数字开14次方。那么以下数字中,        不可能称为其候选答案。

A. 11.0     B. 12.0     C. 13.0     D. 14.0       E. 15.0

 

24. 有3个包,每个包里各放了两个球。包A里的球都是白球,包B里的球都是黑球,包C里的球一黑一白。现随机取一个包,并从中随机取一个球,发现该球是白色的,那么这个包里剩下的球也是白色的概率是          

A. 0    B. 0.33      C. 0.5      D. 0.66         E. 1

 

三、填空与问答(5题,共30分)

25. (4分)某电子眼镜的分辨率为640×360;相当于在距离2.5米左右观看一个25英寸大小的屏幕,其长宽比为16:9。已知蓝牙4.0技术工作在2.4GHz频带,理论最大带宽为24Mbps,请问该眼镜是否可以通过该技术将每秒50帧真彩(24bits,每8个bit用于传输三原色中一种颜色)画面传输至其他屏幕上?如果是,请说明原因。如果否,请说明理论上大约多久才能传送一帧真彩画面。

答案:不能。

           每一个像素需要24bit来存储颜色信息,每一帧共有640*360个像素,需要640*360*24=5529600 bit

           传一帧画面需要的时间=5529600 bit / 24M bit/s = 0.2304 秒

           传50帧所用时间=0.2304*50 = 11.52秒 > 1秒,所以不能每秒传50帧的真彩画面

 

26.(4分)将N条长度均为M的有序链表进行合并,合并以后的链表也保持有序,时间复杂度为         

答案:O(MN*logN)

           这样来想,按照归并排序的思路,每一趟归并需要扫描全部记录,时间复杂度为O(MN),记录本身已经分为N组有序的子序列,对N组子序列作合并,一共需要logN次,所以总复杂度为O(MN*logN)

 

27.(6分)有ABCD四人,要在夜里过一座桥。他们通过这座桥分别耗时1、2、5、10分钟,只有一只手电,并且同时最多只能两个人一起过桥,请你安排过桥方案,能够使这四个人都过桥,且总共花的时间最短。需要给出所花费的时间以及具体方案。

答案:17分钟
           第一趟去:A+B,2分钟

           第一趟回:A,1分钟

           第二趟去:C+D,10分钟

           第二趟回:B,2分钟

           第三趟去:A+B,2分钟

 

28. (8分)下列代码是实现有序证书数组的二分查找(也称为折半查找),请指出其中的bug。

int binary_search( int *array, int length,int key)
{
	intstart = 0, end = length – 1;
	while(end> start)
	{
		int middle = (start + end) / 2;
		int tmp = array[middle];
		if(tmp < key)
		{
			start = middle;
		}
		else if(tmp > key)
		{
			end = middle;
		}
		else
		{
			return middle;
		}
	}
	return -1;
}

答案:1.缺少对非法输入参数的判断

           2.while循环条件应为end>=start

           3.tmp<key时,start变化动作应为start=middle+1

           4.tmp>key时,end变化动作应为end=middle-1


 

29.(8分)有种数据结构叫做跳跃列表(Skip List),它是基于并联的链表随机化数据结构,其效率可比拟于二叉查找树(对于大多数操作需要O(n logn)平均时间)。它是按层建造的,底层是一个普通的有序链表,每个更高层都充当下面列表的“快速跑道”,这里在层i中的元素按概率1/p出现在层i+1中。平均起来,每个元素都在p/(p-1)个列表中出现,而最高层的元素(通常是在跳跃列表前端的一个特殊的头元素)在O(logpn)个列表中出现,调节p的大小可以在内存消耗和时间消耗上进行折中。试分析在该数据结构中查找一个元素的平均时间复杂度。




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值