您的位置:首页 > 编程语言 > Java开发

网易2014校园招聘杭州Java笔试题--题解--第一天

2014-09-29 19:18 337 查看
1.最坏情况下时间复杂度为O(nlogn)的排序算法有()

A、基数排序 B、归并排序、C、堆排序 D、快速排序

一定要拓展:



2.以下说法正确的有()

A、有m阶B-树中,所有的非终端节点至少包含m/2个节点

B、若一个叶节点是某二叉树中的中序遍历的最后一个节点,同时它也是该二叉树前序遍历的最后一个节点

C、插入排序,堆排序,快速排序算法中,快速排序的速度是最快的,所需的附加空间也是最少的 (参考第一题)

D、n个数中已知有k个关键字hash值相同,若用线性探测法将它们存入散列表中,至少需要进行k(k+1)/2次探测

3.有一个长度为7的整形数组,里面存储了采用完全二叉树实现的最小堆。该数组中的所有元素都紧密存储,没有空隙,请问,该数组中可能的元素序列是:() (主要考察最小堆的定义,顺便看看最大堆啊!!!)

A、1 2 3 4 5 6 7

B、1 2 4 3 5 6 7

C、1 2 5 3 4 6 7

D、1 4 2 3 5 6 7

4.一个非连通无向图(无自回路和多重边)有66条边,那么它至少有()个顶点

A、11 B、12 C、13 D、14

连通无向图构成条件:边=顶点数*(顶点数-1)/2,顶点数>=1,所以该函数存在单调递增的单值反函数,所以边与顶点为增函数关系

5.请问变量t的最终结果是多少?()

int t=125 (0111 1011 = 125)

t=t&27 (0001 1101 = 27) 与 同为真为真

t=t^31 (0001 1111=31) 异或 相同为真,不同为假

A、6 B、2013 C、7 D、26

拓展:

或 同为假时为假

6.欧几里得的《几何原本》描述了最解大公约数的算法,针对两个整型a,b(a>b>0)其伪代码如下,请估算该算法的复杂度()

god(a,b)

if b=0

then return god(b,a mod b)

A、O(lgb) B、O(a*b) C、O(a*a) D、O(b*b)

7.当一个TCP连接被正常关闭时,主动关闭一方的状态变迁顺序正确的是:()

A、FIN_WAIT1->FIN_WAIT2->TIME_WAIT

B、SYNC_SENT->LAST_ACK->CLOSED

C、FIN_WAIT1->FIN_WAIT2->CLOSED

D、SYNC_SENT->LAST_ACK->TIME_WAIT

8.OSI七层模型中从低到高(即第一层为物理层)的第三层和第六层分别是:()

A、数据链路层,会话层; B、数据链路层,应用层;

C、网络层,传输层; D、网络层,表示层

拓展:

(OSI)

第一层:物理层

第二层:数据链路层

第三层:网络层

第四层:传输层

第五层:会话层

第六层:表示层

第七层:应用层

(TCP/IP)

第一层:网络接入层

第二层:网络层

第三层:传输层

第四层:应用层

TCP/IP很多了,3次握手,4次挥手,每层的协议,报文格式。。。。看看吧!!!

9。通过磁盘冗余阵列(Redundant Arrays of Inexpensive Disks,RAID)能有效的提升数据存储的可靠性或者访问性能,请问以下哪些冗余策略能增加数据的可靠性?()

A、Raid B、Raid 1 C、Raid 5 D、Raid 6

拓展:

操作系统的知识

10.在分布式系统的实现中,不问的进程之间常常需要交换信息,请问分别运行在两台不同主机的进程A,B,他们之间有哪些常见的策略可以进行通信?()

A、共享内存 B、Unix Domain Socket C、管道 D、tcp/ip 协议 E、UDP 协议

11.可以用来检测多个数据位出错的校验码有:()

A、奇偶校验码 B、CRC码 C、BCD码 5 D、海明码

拓展:

网络知识,操作系统,计算机组成原理

12.以下属于对称加密算法的有:()

A、DES和DSA B、RSA和MD5 C、IDEA和RC4 D、SHA和EIGamal

13.使用伪代码描述勇于字符串匹配的KMP算法:计算该算法最坏情况下的时间复杂度,并给出最坏情况的字符串样式。

1.
在串S和串T中分别设比较的起始的下标i和j
2.
循环直到S中所剩字符串长度小于T的长度或T中所有字符串均比较完毕
2.1如果S[i] = T[j],继续比较S和T的下一个字符;否则
2.2将j向右滑动到next[j]位置,即j = next[j]
2.3如果j = 0,则将i和j分别加1,准备下一趟比较
3.如果T中所有字符均比较完毕,则返回匹配的起始下标,否则返回0

14.

假设当前系统底层提供了Compare&Set操作函数

  声明:bool CAS(type*ptr,type oldval,type newval)

  功能:当输入的oldval和ptr指针指向的当前值一致时,ptr指针指向的值将被设置为newval,并返回TRUE:否则返回FALSE.

  特性:1.保证该函数执行的原子性

2.支持Safe-Memory-Reclamation特性。即,若发现ptr指向的内存和当前线程最后一次访问时发生过变化,则返回FALSE   请利用该CAS操作实现基于链表的无锁队列,队列长度无限。写出必要的数据结构,和入队/出队的伪代码
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: