一、单项选择题,每小题 2 分,共 80 分。
1.为解决计算机与打印机之间速度不匹配的问题,通常设置一个打印数据缓 冲区,主机将要输出的数据依次写入该缓冲区,而打印机则依次从该缓冲区中取 出数据。该缓冲区的逻辑结构应该是 A.栈 B.队列 C.树 D.图
2.设栈 S 和队列 Q 的初始状态均为空,元素 abcdefg 依次进入栈 S。若每个 元素出栈后立即进入队列 Q,且 7 个元素出队的顺序是 bdcfeag,则栈 S 的容量 至少是 A.1 B.2 C.3 D.4
3.给定二叉树图所示。设 N 代表二叉树的根,L 代表根结点的左子树,R 代 表根结点的右子树。若遍历后的结点序列为 3,1,7,5,6,2,4,则其遍历方 式是
A.LRN B.NRL C.RLN D.RNL
4.下列二叉排序树中,满足平衡二叉树定义的是
5.已知一棵完全二叉树的第 6 层(设根为第 1 层)有 8 个叶结点,则完全二 叉树的结点个数最多是 A.39 B.52 C.111 D.119
6.将森林转换为对应的二叉树,若在二叉树中,结点 u 是结点 v 的父结点的 父结点,则在原来的森林中,u 和 v 可能具有的关系是
I.父子关系 II.兄弟关系 III. u 的父结点与 v 的父结点是兄弟关系 A.只有 II B.I 和 II C.I 和 III D.I、II 和 III
7.下列关于无向连通图特性的叙述中,正确的是 I.所有顶点的度之和为偶数 II.边数大于顶点个数减 1 III.至少有一个顶点的度为 1
A.只有 I B. 只有 II C.I 和 II D.I 和 III 8.下列叙述中,不符合m阶B 树定义要求的是
A.根节点最多有 m 棵子树 B.所有叶结点都在同一层上 C.各结点内关键字均升序或降序排列 D.叶结点之间通过指针链接
9.已知关键序列 5,8,12,19,28,20,15,22 是小根堆(最小堆),插入 关键字 3,调整后得到的小根堆是
A.3,5,12,8,28,20,15,22,19 B. 3,5,12,19,20,15,22,8,28 C.3,8,12,5,20,15,22,28,19 D. 3,12,5,8,28,20,15,22,19
10.若数据元素序列 11,12,13,7,8,9,23,4,5 是采用下列排序方法 之一得到的第二趟排序后的结果,则该排序算法只能是
A.起泡排序 B.插入排序 C.选择排序 D.二路归并排序
11.冯•诺依曼计算机中指令和数据均以二进制形式存放在存储器中,CPU 区分它们的依据是
A.指令操作码的译码结果 B.指令和数据的寻址方式 C.指令周期的不同阶段 D.指令和数据所在的存储单元
12.一个 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
13.浮点数加减运算过程一般包括对阶、尾数运算、规格化、舍入和判溢出 等步骤。设浮点数的阶码和尾数均采用补码表示,且位数分别为 5 位和 7 位(均 含 2 位符号位)。若有两个数 X=27×29/32,Y=25×5/8,则用浮点加法计算 X+Y 的最终结果是 A.00111 1100010 B.00111 0100010 C.01000 0010001 D.发生溢出
14.某计算机的 Cache 共有 16 块,采用 2 路组相联映射方式(即每组 2 块)。 每个主存块大小为 32 字节,按字节编址。主存 129 号单元所在主存块应装入到 的 Cache 组号是 A.0 B.2 C.4 D.6
15.某计算机主存容量为 64KB,其中 ROM 区为 4KB,其余为 RAM 区,按字节 编址。现要用 2K×8 位的 ROM 芯片和 4K×4 位的 RAM 芯片来设计该存储器,则需 要上述规格的 ROM 芯片数和 RAM 芯片数分别是 A.1、15 B.2、15 C.1、30 D.2、30
16.某机器字长 16 位,主存按字节编址,转移指令采用相对寻址,由两个字 节组成,第一字节为操作码字段,第二字节为相对位移量字段。假定取指令时, 每取一个字节 PC 自动加 1。若某转移指令所在主存地址为 2000H,相对位移量字 段的内容为 06H,则该转移指令成功转以后的目标地址是 A.2006H B.2007H C.2008H D.2009H 17.下列关于 RISC 的叙述中,错误的是 A.RISC 普遍采用微程序控制器
B.RISC 大多数指令在一个时钟周期内完成 C.RISC 的内部通用寄存器数量相对 CISC 多
D.RISC 的指令数、寻址方式和指令格式种类相对 CISC 少
18.某计算机的指令流水线由四个功能段组成,指令流经各功能段的时间(忽 略各功能段之间的缓存时间)分别是 90ns、80ns、70ns 和 60ns,则该计算机的 CPU 时钟周期至少是 A.90ns B.80ns C.70ns D.60ns
19.相对于微程序控制器,硬布线控制器的特点是 A.指令执行速度慢,指令功能的修改和扩展容易 B.指令执行速度慢,指令功能的修改和扩展难 C.指令执行速度快,指令功能的修改和扩展容易
D.指令执行速度快,指令功能的修改和扩展难
20.假设某系统总线在一个总线周期中并行传输 4 字节信息,一个总线周期 占用 2 个时钟周期,总线时钟频率为 10MHz,则总线带宽是
A.10MB/s B.20MB/S C.40MB/S D.80MB/S
21.假设某计算机的存储系统由 Cache 和主存组成,某程序执行过程中访存 1000 次,其中访问 Cache 缺失(未命中)50 次,则 Cache 的命中率是 A.5% B.9.5% C.50% D.95%
22.下列选项中,能引起外部中断的事件是
A.键盘输入 B.除数为 0 C.浮点运算下溢 D.访存缺页
23.单处理机系统中,可并行的是
I 进程与进程 II 处理机与设备 III 处理机与通道 IV 设备与设备 A.I、II 和 III B. I、II 和 IV C. I、III 和 IV D. II、III 和 IV 24.下列进程调度算法中,综合考虑进程等待时间和执行时间的是
A.时间片轮转调度算法 B.短进程优先调度算法 C.先来先服务调度算法 D.高响应比优先调度算法 25.某计算机系统中有 8 台打印机,有 K 个进程竞争使用,每个进程最多需 要 3 台打印机。该系统可能会发生死锁的 K 的最小值是 A.2 B.3 C.4 D.5
26.分区分配内存管理方式的主要保护措施是 A.界地址保护 B.程序代码保护 C.数据保护 D.栈保护
27.一个分段存储管理系统中,地址长度为 32 位,其中段号占 8 位,则最大 段长是 A.28 字节 B.216 字节 C.224 字节 D.232 字节
28.下列文件物理结构中,适合随机访问且易于文件扩展的是
A.连续结构 B.索引结构 C.链式结构且磁盘块定长 D.链式结构且磁盘块变长
29.假设磁头当前位于第 105 道,正在向磁道序号增加的方向移动。现有一 个磁道访问请求序列为 35,45,12,68,110,180,170,195,采用 SCAN 调度 (电梯调度)算法得到的磁道访问序列是 A.110,170,180,195,68,45,35,12 B.110,68,45,35,12,170,180,195 C.110,170,180,195,12,35,45,68 D.12,35,45,68,110,170,180,195
30.文件系统中,文件访问控制信息存储的合理位置是 A.文件控制块 B.文件分配表 C.用户口令表 D.系统注册表
31.设文件 F1 的当前引用计数值为 1,先建立 F1 的符号链接(软链接)文 件 F2,再建立 F1 的硬链接文件 F3,然后删除 F1。此时,F2 和 F3 的引用计数值 分别是 A.0、1 B.1、1 C.1、2 D.2、1
32.程序员利用系统调用打开 I/O 设备时,通常使用的设备标识是 A.逻辑设备名 B.物理设备名 C.主设备号 D.从设备号
33.在 OSI 参考模型中,自下而上第一个提供端到端服务的层次是 A.数据链路层 B.传输层 C.会话层 D.应用层
34.在无噪声情况下,若某通信链路的带宽为 3kHz,采用 4 个相位,每个相 位具有 4 种振幅的 QAM 调制技术,则该通信链路的最大数据传输速率是 A.12kbps B.24 kbps C.48 kbps D.96 kbps
35.数据链路层采用了后退 N 帧(GBN)协议,发送方已经发送了编号为 0~7 的帧。当计时器超时时,若发送方只收到 0、2、3 号帧的确认,则发送方需要重 发的帧数是 A.2 B.3 C.4 D.5
36.以太网交换机进行转发决策时使用的 PDU 地址是
A.目的物理地址 B.目的 IP 地址 C.源物理地址 D.源 IP 地址
37.在一个采用 CSMA/CD 协议的网络中,传输介质是一根完整的电缆,传输 速率为 1Gbps,电缆中的信号传播速度是 200 000km/s。若最小数据帧长度减少
800 比特,则最远的两个站点之间的距离至少需要 A.增加 160m B.增加 80m C.减少 160m D.减少 80m
38.主机甲和主机乙间已建立一个 TCP 连接,主机甲向主机乙发送了两个连 续的 TCP 段,分别包含 300 字节和 500 字节的有效载荷,第一个段的序列号为
200,主机乙正确接收到两个段后,发送给主机甲的确认序列号是 A.500 B.700 C.800 D.1000
39.一个 TCP 连接总是以 1KB 的最大段发送 TCP 段,发送方有足够多的数据 要发送。当拥塞窗口为 16KB 时发生了超时,如果接下来的 4 个 RTT(往返时间) 时间内的 TCP 段的传输都是成功的,那么当第 4 个 RTT 时间内发送的所有 TCP 段都得到肯定应答时,拥塞窗口大小是 A.7KB B. 8KB C. 9KB D. 16KB
40.FTP 客户和服务器间传递 FTP 命令时,使用的连接是
A.建立在 TCP 之上的控制连接 B. 建立在 TCP 之上的数据连接 C. 建立在 UDP 之上的控制连接 D. 建立在 UDP 之上的数据连接 二、综合应用题。共 70 分。 41.(10 分)
带权图(权值非负,表示边连接的两顶点间的距离)的最短路 径问题是找出从初始顶点到目标顶点之间的一条最短路径。假定从初始顶点到目 标顶点之间存在路径,现有一种解决该问题的方法: ①设最短路径初始时仅包含初始顶点,令当前顶点 u 为初始顶点;
②选择离 u 最近且尚未在最短路径中的一个顶点 v,加入到最短路径中,修改当前顶点 u=v;
③重复步骤②,直到 u 是目标顶点时为止。 请问上述方法能否求得最短路径?若该方法可行,请证明之;否则,请举例说明。
42.(15 分)已知一个带有表头结点的单链表,结点结构为 date link
假设该链表只给出了头指针 list。在不改变链表的前提下,请设计一个尽可能 高效的算法,查找链表中倒数第 k 个位置上的结点(k 为正整数)。若查找成功, 算法输出该结点的 data 值,并返回 1;否则,只返回 0。要求:
(1) 描述算法的基本设计思想 (2) 描述算法的详细实现步骤
(3) 根据设计思想和实现步骤,采用程序设计语言描述算法(使用 C 或 C++ 或 JAVA 语言实现),关键之处请给出简要注释
43.(8 分)某计算机的 CPU 主频为 500MHz,CPI 为 5(即执行每条指令平均 需 5 个时钟周期)。假定某外设的数据传输率为 0.5MB/s,采用中断方式与主机 进行数据传送,以 32 位为传输单位,对应的中断服务程序包含 18 条指令,中断 服务的其他开销相当于 2 条指令的执行时间。请回答下列问题,要求给出计算过 程。
(1)在中断方式下,CPU 用于该外设 I/O 的时间占整个 CPU 时间的百分比 是多少?
(2)当该外设的数据传输率达到 5MB/s 时,改用 DMA 方式传送数据。假设 每次 DMA 传送大小为 5000B,且 DMA 预处理和后处理的总开销为 500 个时钟周期, 则 CPU 用于该外设 I/O 的时间占整个 CPU 时间的百分比是多少?(假设 DMA 与 CPU 之间没有访存冲突)
44.(13 分)某计算机字长 16 位,采用 16 位定长指令字结构,部分数据通 路结构如图所示。图中所有控制信号为 1 时表示有效、为 0 时表示无效。例如控 制信号 MDRinE 为 1 表示允许数据从 DB 打入 MDR,MDRin 为 1 表示允许数据从内 总线打入 MDR。假设 MAR 的输出一直处于使能状态。加法指令“ADD(R1),R0” 的功能为(R0)+((R1))→(R1),即将 R0 中的数据与 R1 的内容所指主存单元 的数据相加,并将结果送入 R1 的内容所指主存单元中保存。
数据通路结构 下表给出了上述指令取值和译码阶段每个节拍(时钟周期)的功能和有效控 制信号,请按表中描述方式用表格列出指令执行阶段每个节拍的功能和有效控制信号。 功能和控制信号
时钟 C1 C2 C3 C4
功能 MAR←(PC) MDR←M(MAR) IR←(MDR) 指令译码 有效控制信号 PCout,MARin MemR,MDRinE MDRout,IRin 无 45.(7 分)三个进程 P1、P2、P3 互斥使用一个包含 N(N>0)个单元的缓冲 区。P1 每次用 produce()生成一个正整数并用 put()送入缓冲区某一空单元 中;P2 每次用 getodd()从该缓冲区中取出一个奇数并用 countodd()统计奇 数个数;P3 每次用 geteven()从该缓冲区中取出一个偶数并用 counteven() 统计偶数个数。请用信号量机制实现这三个进程的同步与互斥活动,并说明所定 义的信号量的含义。要求用伪代码描述。
46.(8 分)请求分页管理系统中,假设某进程的页表内容如下表所示。 页表内容
页号 0 1 2
页面大小为 4KB,一次内存的访问时间是 100ns,一次快表(TLB)的访问时 间是 10ns,处理一次缺页的平均时间为 108ns(已含更新 TLB 和页表的时间), 进程的驻留集大小固定为 2,采用最近最少使用置换算法(LRU)和局部淘汰策 略。假设①TLB 初始为空;②地址转换时先访问 TLB,若 TLB 未命中,再访问页 表(忽略访问页表之后的 TLB 更新时间);③有效位为 0 表示页面不在内存,产 生缺页中断,缺页中断处理后,返回到产生缺页中断的指令处重新执行。设有虚 地址访问序列 2362H、1565H、25A5H,请问:
(1) 依次访问上述三个虚地址,各需多少时间?给出计算过程。
(2) 基于上述访问序列,虚地址 1565H 的物理地址是多少?请说明理由。
47.(9 分)希赛公司网络拓扑图如下图所示,路由器 R1 通过接口 E1、E2 分别连接局域网 1、局域网 2,通过接口 L0 连接路由器 R2,并通过路由器 R2 连 接域名服务器与互联网。R1 的 L0 接口的 IP 地址是 202.118.2.1;R2 的 L0 接口 的 IP 地址是 202.118.2.2,L1 接口的 IP 地址是 130.11.120.1,E0 接口的 IP 地址是 202.118.3.1;域名服务器的 IP 地址是 202.118.3.2。 答案如下: 一、选择题
1 B 11 C 21 D 31 B 页框(Page Frame)号 101H — 254H 有效位(存在位) 1 0 1 2 C 12 D 22 A 32 A 3 D 13 D 23 D 33 B 4 B 14 C 24 D 34 B 5 C 15 D 25 C 35 C 6 B 16 C 26 A 36 A 7 A 17 A 27 C 37 D 8 D 18 A 28 B 38 D 9 A 19 D 29 A 39 C 10 B 20 B 30 A 40 A
二、综合应用题
41.该方法求得的路径不一定是最短路径。例如,对于下图所示的带权图,如果 按照题中的原则,从A到C 的最短路径为 A→B→C,事实上其最短路径为 A→D→C。
42.
(1)算法基本思想如下:从头至尾遍历单链表,并用指针 p 指向当前结点的前 k 个结点。当遍历到链表的最后一个结点时,指针 p 所指向的结点即为所查 找的结点。
(2)详细实现步骤:增加两个指针变量和一个整型变量,从链表头向后遍 历,其中指针 p1 指向当前遍历的结点,指针 p 指向 p1 所指向结点的前 k 个结点, 如果 p1 之前没有 k 个结点,那么 p 指向表头结点。用整型变量 i 表示当前遍历 了多少个结点,当 i>k 时,指针 p 随着每次遍历,也向前移动一个结点。当遍历 完成时,p 或者指向表头结点,或者指向链表中倒数第 k 个位置上的结点。 (3)算法描述:
int LocateElement(Linklist list,int k) {
p1=list->link; p=list; i=1; while(p1) {
p1=p1->link; i++;
if(i>k) p=p->next; //如果 i>k,则 p 也往后移 }
if(p==list) return 0; //说明链表没有 k 个结点 else {
printf(“%d\\n“,p->data); return 1; } } 43.
(1)在中断方式下,每 32 位(4B)被中断一次,故每秒中断
0.5MB/4B=0.5×106/4=12.5×104 次 要注意的是,这里是数据传输率,所以 1MB=106B。因为中断服务程序包含 18条指令,中断服务的其他开销相当于 2 条指令的执行时间,且执行每条指令平均 需 5 个时钟周期,所以,1 秒内用于中断的时钟周期数为 (18+2)×5×12.5×104=12.5×106 (2)在 DMA 方式下,每秒进行 DMA 操作
5MB/5000B=5×106/5000=1×103 次因为 DMA 预处理和后处理的总开销为 500 个时钟周期,所以 1 秒钟之内用于 DMA 操作的时钟周期数为 500×1×103=5×105
故在 DMA 方式下,占整个 CPU 时间的百分比是 ((5×105)/(500×106))×100%=0.1%
44.指令执行阶段每个节拍的功能和有效控制信号如下所示 时钟 C5 C6 C7 C8 C9 C10 功能 MAR←(R1) MDR←M(MAR) A←(R0) AC←(MDR)+(A) MDR←(AC) M(MAR) ←MDR 有效控制信号 PCout,MARin MemR,MDRinE R0out,Ain MDRout,Addr,ACin ACout,MDRin MDRoutE,MemW 45.定义信号量 S1 控制 P1 与 P2 之间的同步;S2 控制 P1 与 P3 之间的同步;empty 控制生产者与消费者之间的同步;mutex 控制进程间互斥使用缓冲区。程序如下: Var s1=0,s2=0,empty=N,mutex=1; Parbegin P1:begin
X=produce(); /*生成一个数*/
P(empty); /*判断缓冲区是否有空单元*/ P(mutex); /*缓冲区是否被占用*/ Put(); If x%2==0
V(s2); /*如果是偶数,向 P3 发出信号*/ else
V(s1); /*如果是奇数,向 P2 发出信号*/ V(mutex); /*使用完缓冲区,释放*/ end. P2:begin
P(s1); /*收到 P1 发来的信号,已产生一个奇数*/ P(mutex); /*缓冲区是否被占用*/
Getodd(); Countodd():=countodd()+1; V(mutex); /*释放缓冲区*/ V(empty); /*向 P1 发信号,多出一个空单元*/ end. P3:begin
P(s2) /*收到 P1 发来的信号,已产生一个偶数*/ P(mutex); /*缓冲区是否被占用*/
Geteven(); Counteven():=counteven()+1; V(mutex); /*释放缓冲区*/
V(empty); /*向 P1 发信号,多出一个空单元*/ end. Parend. 46.
(1)根据页式管理的工作原理,应先考虑页面大小,以便将页号和页内位移分解出来。页面大小为 4KB,即 212,则得到页内位移占虚地址的低 12 位,页 号占剩余高位。可得三个虚地址的页号 P 如下(十六进制的一位数字转换成 4 位二进制,因此,十六进制的低三位正好为页内位移,最高位为页号): 2362H:P=2,访问快表 10ns,因初始为空,访问页表 100ns 得到页框号,合成物理地址后访问主存 100ns,共计 10ns+100ns+100ns=210ns。
1565H:P=1,访问快表 10ns,落空,访问页表 100ns 落空,进行缺页中断处理 108ns,合成物理地址后访问主存 100ns,共计 10ns+100ns+108ns+100ns≈108ns。
25A5H:P=2,访问快表,因第一次访问已将该页号放入快表,因此花费 10ns便可合成物理地址,访问主存 100ns,共计 10ns+100ns=110ns
(2)当访问虚地址 1565H 时,产生缺页中断,合法驻留集为 2,必须从页表 中淘汰一个页面,根据题目的置换算法,应淘汰 0 号页面,因此 1565H 的对应页 框号为 101H。由此可得 1565H 的物理地址为 101565H。 47.
(1)无类 IP 地址的核心是采用不定长的网络号和主机号,并通过相应的子网掩码来表示(即网络号部分为 1,主机号部分为 0)。本题中网络地址位数是
24,由于 IP 地址是 32 位,因此其主机号部分就是 8 位。因此,子网掩码就是 11111111 11111111 11111111 00000000,即 255.255.255.0。
根据无类 IP 地址的规则,每个网段中有两个地址是不分配的:主机号全 0 表示网络地址,主机号全 1 表示广播地址。因此 8 位主机号所能表示的主机数就 是 28-2,即 254 台。
该网络要划分为两个子网,每个子网要 120 台主机,因此主机位数 X 应该满 足下面三个条件: X<8,因为是在主机号位长为 8 位的网络进行划分,所以 X 一定要小于 8 位。 2x>120,因为根据题意需要容纳 120 台主机。 X 是整数。
解 上 述 方 程 , 得 到 X=7. 子 网 掩 码 就 是 11111111 11111111 11111111
10000000,即 255.255.255.128。 所以划分的两个网段是:202.118.1.0/25 与 202.118.1.128/25。
(2)填写 R1 的路由表
填写到局域网 1 的路由。局域网 1 的网络地址和掩码在问题(1)已经求出 来了,为 202.118.1.0/25。则 R1 路由表应填入的网络地址为 202.118.1.0,掩 码为 255.255.255.128。由于局域网 1 是直接连接到路由器 R1 的 E1 口上的,因 此,下一跳地址填写直接路由(Direct)。接口填写 E1.
填写到局域网 2 的路由表 1。局域网 2 的网络地址和掩码在问题(1)中已经 求出来了,为 202.118.1.128/25 。 则 R1 路 由 表 应该填入的网络地址为
202.118.1.128,掩码为 255.255.255.128.由于局域网 2 是直接连接到路由器 R1 的 E2 口上的,因此,下一跳地址填写直接路由。接口填写 E2。
填写到域名服务器的路由。由于域名服务器的 IP 地址为 202.118.3.2,而该 地址为主机地址,因此掩码为 255.255.255.255。同时,路由器 R1 要到 DNS 服 务器,就需要通过路由器 R2 的接口 L0 才能到达,因此下一跳地址填写 L0 的 IP 地址(202.118.2.2)。
填写互联网路由。本题实质是编写默认路由。默认路由是一种特殊的静态路 由,指的是当路由表中与包的目的地址之间没有匹配的表项时路由器能够做出的 选择。如果没有默认路由器,那么目的地址在路由表中没有匹配表项的包将被丢 弃。默认路由在某些时候非常有效,当存在末梢网络时,默认路由会大大简化路 由器的配置,减轻管理员的工作负担,提高网络性能。默认路由叫做“0/0”路 由,因为路由的 IP 地址 0.0.0.0,而子网掩码也是 0.0.0.0。同时路由器 R1 连 接的网络需要通过路由器 R2 的 L0 口才能到达互联网络,因此下一跳地址填写 L0 的 IP 为 202.118.2.2。 综上,填写的路由表如下:
R1路由器 目的网络 IP 地址 202.118.1.0 202.118.1.128 202.118.3.2 0.0.0.0 子网掩码 255.255.255.128 255.255.255.128 255.255.255.255 0.0.0.0 下一跳 IP 地址 Direct Direct 202.118.2.2 202.118.2.2 接口 E1 E2 L0 L0 (3)填写 R2 到局域网 1 和局域网 2 的路由表 2。局域网 1 和局域网 2 的地址可以聚合为202.118.1.0/24,而 R2 去往局域网 1 和局域网 2 都是同一条路径。 因此,路由表里面只需要填写到 202.118.1.0/24 网络的路由即可,如下表所示 R2 路由表 目的网络 IP 地址 202.118.1.0 子网掩码 255.255.255.0 下一跳 IP 地址 202.118.2.1 接口 L0
2010年计算机考研真题以及答案
一、单项选择题:1-40题,每题20分共80分。在每个小题给出的四个选项中选正确答案。
1、若元素a、b、c、d、e、f依次进栈,允许进栈、退栈操作交替进行,但不允许连续三次进行退栈工作,则不可能得到的出栈序列是() A、dcebfa B、cbdaef C、bcaefd D、afedcb
2、某队列允许在其两端进行入队操作,但仅允许在一端进行出队操作,则不可能得到的顺顺序是() A、bacde B、dbace C、dbcae D、ecbad
3、下列线索二叉树中(用虚线表示线索),符合后序线索树定义的是()
4、在下列所示的平衡二叉树中插入关键字48后得到一棵新平衡二叉树,在新平衡二叉树中,关键字37所在结点的左、右子结点中保存的关键字分别是() A、13,48 B、24,48 C、24,53 D、24,90
5、在一棵度数为4的树T中,若有20个度为4的结点,10个度为3的结点,1个度为2的结点,10个度为1的结点,则树T的叶结点个数是() A、41 B、82 C、113 D、122
6、对n(n>=2)个权值均不相同的字符构成哈弗曼树,关于该树的叙述中,错误的是() A、该树一定是一棵完全二交叉 B、树中一定没有度为1的结点
C、树中两个权值最小的结点一定是兄弟结点
D、树中任一非叶结点的权值一定不小于下一层任一结点的权值
7、若无向图G=(V.E)中含7个顶点,则保证图G在任何情况下都是连通的,则需要的边数最少是() A、6 B、15 C、16 D、21
8、对下图进行拓扑排序,可以得到不同的拓扑序列的个数是() A、4 B、3 C、2 D、1
9、已知一个长度为16的顺序表L,其元素按关键字有序排列,若采用折半查找法查找一个不存在的元素,则比较次数最多的是() A、4
B、5 C、6 D、7
10、采用递归方式对顺序表进行快速排序,下列关于递归次数的叙述中,正确的是() A、递归次数于初始数据的排列次数无关
B、每次划分后,(勤思考研)先处理较长的分区可以减少递归次数(勤思考研) C、每次划分后,先处理较短的分区可以减少递归次数 D、递归次数与每次划分后得到的分区处理顺序无关
11、对一组数据(2,12,16,88,5,10)进行排序,若前三趟排序结果如下:() 第一趟:2,12,16,5,10,88 第二趟:2,12,5,10,16,88 第三趟:2,5,10,12,16,88 则采用的排序方法可能是
A.冒泡排序法 B.希尔排序法 C.归并排序法
D.基数排序法
12.下列选项中,能缩短程序执行时间的措施是()
1.提高CPU时钟频率 2.优化通过数据结构 3.优化通过程序
A.仅1和2
B.仅1和3 C,仅2和3
D.1,2,3
13.假定有4个整数用8位补码分别表示r1=FEH,r2=F2H,r3=90H,r4=F8H,若将运算结果存放在一个8位寄存器中,则下列运算会发生益处的是()
A. r1 x r2 B. r2 x r3 C. r1 x r4 D. r2 x r4
14.假定变量i,f,d数据类型分别为int, float, double(int用补码表示,float和double用IEEE754单精度和双精度浮点数据格式表示),已知i=785,f=1.5678e3,d=1.5e100,若在32位机器中执行下列关系表达式,(勤思考研)则结果为真的是()
(I) i==(int)(float)I (II)f==(float)(int)f (III)f==(float)(double)f (IV)(d+f)-d==f
A. 仅I和II B. 仅I和III C. 仅II和III D. 仅III和IV
15.假定用若干个2K x 4位芯片组成一个8K x 8为存储器,则0B1FH所在芯片的最小地址是()
A.0000H B.0600H C.0700H
D.0800H
16.下列有关RAM和ROM得叙述中正确的是() I RAM是易失性存储器,ROM是非易失性存储器 II RAM和ROM都是采用随机存取方式进行信息访问 III RAM和ROM都可用做Cache IV RAM和ROM都需要进行刷新 A. 仅I和II B. 仅II和III C. 仅I ,II, III D. 仅II,III,IV
17.下列命令组合情况,一次访存过程中,不可能发生的是() A.TLB未命中,Cache未命中,Page未命中 B.TLB未命中,Cache命中,Page命中 C.TLB命中,Cache未命中,Page命中 D.TLB命中,Cache命中,Page未命中
18.下列寄存器中,反汇编语言程序员可见的是()
A.存储器地址寄存器(MAR) B.程序计数器(PC)
C.存储区数据寄存器(MDR) D.指令寄存器(IR)
19.下列不会引起指令流水阻塞的是() A.数据旁路 B.数据相关 C.条件转移 D.资源冲突
20.下列选项中的英文缩写均为总线标准的是() A. PCI、CRT、USB、EISA B. ISA、CPI、VESA、EISA C. ISA、SCSI、RAM、MIPS D. ISA、EISA、PCI、PCI-Express
21、单级中断系统中,中断服务程序执行顺序是() I保护现场 II开中断 III关中断 IV保存断点 V中断事件处理 VI恢复现场 VII中断返回 A、I->V->VI->II->VII B、III->I->V->VII C、III->IV->V->VI->VII D、IV->I->V->VI->VII
22、假定一台计算机的显示存储器用DRAM芯片实现,(勤思考研)若要求显示分辨率为1600*1200,颜色深度为24位,帧频为85HZ,现实总带宽的50%用来刷新屏幕,则需要的显存总带宽至少约为()
A、245Mbps B、979Mbps C、1958Mbps D、7834Mbps
23、下列选项中,操作S提供的给应程序的接口是() A、系统调用 B、中断 C、库函数 D、原语
24、下列选项中,导制创进新进程的操作是() I用户登陆成功 II设备分配 III启动程序执行 A、仅I和II B、仅II和III C、仅I和III D、I、II、III
25、设与某资源相关联的信号量初值为3,当前值为1,若M表示该资源的可用个数,(勤思考研)示等待该资源的进程数,则M,N分别是() A、0,1 B、1,0 C、1,2 D、2,0
26、下列选项中,降低进程优先权级的合理时机是() A、进程的时间片用完
B、进程刚完成I/O,进入就绪列队 C、进程长期处于就绪列队 D、进程从就绪状态转为运行状态
27、进行PO和P1的共享变量定义及其初值为()
booleam flag[2]; int turn=0;
flag[0]=false; flag[1]=false;
若进行P0和P1访问临界资源的类C代码实现如下:
void p0() // 进程p0 void p1 () // 进程p1
{ {
while (TRUE){ while (TRUE){
flag[0]=TRUE; turn=1; flag[0]=TRUE; turn=0; While (flag[1]&&(turn==1)); While (flag[0]&&(turn==0));
临界区; 临界区;
flag[0]=FALSE; flag[1]=FALSE; } } } }
则并发执行进程PO和P1时产生的情况是( ) A、不能保证进程互斥进入临界区,会出现“饥饿”现象 B、不能保证进程互斥进入临界区,不会出现“饥饿”现象 C、能保证进程互斥进入临界区,会出现“饥饿”现象
N表D、能保证进程互斥进入临界区,不会出现“饥饿”现象
28、某基于动态分区存储管理的计算机,其主存容量为55Mb(初始为空),(勤思考研)采用最佳适配(Best Fit)算法,分配和释放的顺序为:分配15Mb,分配30Mb,释放15Mb,分配8M, 分配6Mb,此时主存中最大空闲分区的大小是() A、7Mb B、9Mb C、10Mb D、15Mb
29、某计算机采用二级页表的分页存储管理方式,按字节编制,页大小为2(10)【2的10次方,下同】字节,页表项大小为2字节,逻辑地址结构为
页目录号 页号 页内偏移量 逻辑地址空间大小为2(10)页,则表示整个逻辑地址空间的页目录表中包含表项的个数至少是() A、64 B、128 C、256 D、512
30.设文件索引节点中有7个地址项,其中4个地址为直接地址索引,(勤思考研)1个地址项是二级间接地址索引,每个地址项的大小为4字节,若磁盘索引块和磁盘数据块大小均为256字节,则可表示的单个文件最大长度是()
A. 33KB B. 519KB C. 1057KB D. 16513KB
31. 设当前工作目录的主要目的是() A. 节省外存空间 B. 节省内存空间 C. 加快文件的检索速度 D. 加快文件的读写速度
32.本地用户通过键盘登陆系统是,首先获得键盘输入信息的程序时() A. 命令解释程序 B. 中断处理程序 C. 系统调用程序 D. 用户登录程序
33. 下列选项中,不属于网络体系结构中所描述的内容是() A.网络的层次 B.每一层使用的协议 C.协议的内部实现细节 D.每一层必须完成的功能
34.在下图所表示的采用”存储-转发”方式分组的交换网络中所有的链路的数据传输速度为100Mbps,分组大小为1000B,其中分组头大小为20B若主机H1向主机H2发送一个大小为980000的文件,(勤思考研)则在不考虑分组拆装时间和传播延迟的情况下,从H1发送到H2接受完为止,需要的时间至少是()
A.80ms B. 80.08ms C. 80.16ms
D. 80.24ms
35.某自治系统采用RIP协议,若该自治系统内的路由器R1收到其邻居路由器R2的距离矢量中包含的信息 36.若路由器R因为拥塞丢弃IP分组,则此时R可向发出该IP分组的源主机的ICMP报文件的类型是() A. 路由重定向 B. 目的不可达 C. 源抑制 D. 超时 37、某网络的IP地址空间为192.168.5.0/24采用长子网划分,子网掩码为255.255.255.248,则该网络的最大子网个数、每个子网内的最大可分配地址个数为() A、32,8 B、32,6 C、8,32 D、8,30 38、下列网络设备中,能够抑制网络风暴的是() I中断器 II集线器 III网桥 IV路由器 A、仅I和II B、仅III C、仅III和IV D、仅IV 39、主机甲和主机乙之间建立一个TCP连接,TCP最大段长度为1000字节,(勤思考研)若主机甲的当前拥塞窗口为4000字节,在主机甲向主机乙连续发送2个最大段后,成功收到主机乙发送的第一段的确认段,确认段中通告的接收窗口大小为2000字节,则此时主机甲还可以向主机乙发送的最大字节数是() A、1000 B、2000 C、3000 D、4000 40、如果本地域名服务无缓存,当采用递归方法解析另一网络某主机域名时,用户主机本地域名服务器发送的域名请求条数分别为() A、1条,1条 B、1条,多条 C、多条,1条 D、多条,多条 二、综合应用题:41-47小题,共70分 41.(10分)将关键字序列(7、8、30、11、18、9、14)散列存储到散列表中,(勤思考研)散列表的存储空间是一个下标从0开始的一个一维数组散列,函数为: H(key)=(key x 3)MODT,处理冲突采用线性探测再散列法,要求装载因子为0.7 问题: (1).请画出所构造的散列表。 (2).分别计算等概率情况下,查找成功和查找不成功的平均查找长度。 42.(13分)设将n(n>1)个整数存放到一维数组R中。设计一个在时间和空间两方面尽可能高效的算法。将R中的序列循环左移P(0 (2)、根据设计思想,采用C或C++或JAVA语言描述算法,关键之处给出注释。 (3)、说明你所设计算法的时间复杂度和空间复杂度。 43、(11分)某计算机字节长为16位,主存地址空间大小为128KB,按字编址。采用字长指令格式,指令名字段定义如下: 15 12 11 6 5 0 OP M5 R5 Md Rd 源操作数 目的操作数 转移指令采用相对寻址,相对偏移是用补码表示,寻址方式定义如下: Ms/Md 000B 001B 010B 011B 寻址方式 寄存器直接 寄存器间接 寄存器间接、自增 相对 助记符 含义 操作数=(Rn) 操作数=((Rn)) 操作数=((Rn)),(Rn)+1->Rn 转移目标地址=(PC)+(Rn) Rn (Rn) (Rn)+ D(Rn) 注:(X)表示有存储地址X或寄存器X的内容,请回答下列问题: (1)、该指令系统最多可有多少指令?该计算机最多有多少个通用寄存器?(勤思教育)存储地址寄存器(M AR)和存储数据寄存器(MDR)至少各需多少位? (2)、转移指令的目标地址范围是多少? (3)、若操作码0010B表示加法操作(助记符为add),寄存器R4和R5得编号分别为100B何101B,R4的 内容为1234H,R5的内容为5678H,地址1234H中的内容为5678H,5678H中的内容为1234H,则汇编语言为add(R4),(R5) (逗号前为源操作符,逗号后目的操作数) 对应的机器码是什么(用十六进制)?该指令执行后,(勤思教育)哪些寄存器和存储单元的内容会改变?改变后的内容是什么? 44、(12分)某计算机的主存地址空间大小为256M,按字节编址。指令Cache分离,均有8个Cache行, 每个Cache行大小为64MB,数据Cache采用直接映射方式,(勤思教育)现有两个功能相同的程序A和B,其伪代码如下: 程序A: int a[256][256]; ...... int sum_array1() { int i, j, sum = 0; for (i = 0; i < 256; i++) for (j= 0; j < 256; j++) sum += a[i][j]; return sum; } 程序B: int a[256][256]; ...... int sum_array2() { int i, j, sum = 0; for (j = 0; j < 256; j++) for (i= 0; i < 256; i++) sum += a[i][j]; return sum; } 假定int类型数据用32位补码表示,程序编译时i,j,sum均分配在寄存器中,数组a按行优先方式存放,其地址为320(十进制)。请回答,要求说明理由或给出计算过程。 (1)、若不考虑用于Cache一致维护和替换算法的控制位,则数据Cache的总容量为多少? (2)、数组元素a[0][31]和a[1][1]各自所在的主存块对应的Cache行号分别是多少(Cache行号从0开始) (3)、程序A和B得数据访问命中率各是多少?哪个程序的执行时间短? 45、(7分)假设计算机系统采用CSCAN(循环扫描)磁盘调度策略,使用2KB的内存空间记录16384个磁 盘的空闲状态 (1)、请说明在上述条件如何进行磁盘块空闲状态的管理。 (2)、设某单面磁盘的旋转速度为每分钟6000转,(勤思教育)每个磁道有100个扇区,相临磁道间的平 均移动的时间为1ms. 若在某时刻,磁头位于100号磁道处,并沿着磁道号增大的方向移动(如下图所示),磁道号的请求队列为50,90,30,120对请求队列中的每个磁道需读取1个随机分布的扇区,则读完这个扇区点共需要多少时间?需要给出计算过程。 46.(8分)设某计算机的逻辑地址空间和物理地址空间均为64KB,按字节编址。(勤思教育)某进程最多需要6页数据存储空间,页的大小为1KB,操作系统采用固定分配局部置换策略为此进程分配4个页框。 页号 页框号 装入时间 访问位 0 1 2 3 7 4 2 9 130 230 200 160 1 1 1 1 当该进程执行到时刻260时,要访问逻辑地址为17CAH的数据。请回答下列问题: (1)、该逻辑地址对应的页号时多少? (2)、若采用先进先出(FIFO)置换算法,该逻辑地址对应的物理地址?要求给出计算过程。 (3)、采用时钟(Clock)置换算法,该逻辑地址对应的物理地址是多少?要求给出计算过程。(设搜索下一页 的指针按顺时针方向移动,且指向当前2号页框,示意图如下) 47、(9分)某局域网采用CSMA/CD协议实现介质访问控制,数据传输率为100M/S,主机甲和主机已的 距离为2KM,信号传播速速时200000M/S请回答下列问题,并给出计算过程。 (1)、若主机甲和主机已发送数据时发生冲突,则从开始发送数据时刻起,到两台主机均检测到冲突时 刻为止,最短经过多长时间?最长经过多长时间?(假设主机甲和主机已发送数据时,其它主机不发送数据) (2)、若网络不存在任何冲突与差错,主机甲总是以标准的最长以太数据帧(1518字节)向主机已发送数据,主机已每成功收到一个数据帧后,立即发送下一个数据帧,(勤思教育)此时主机甲的有效数据传输速率是多少?(不考虑以太网帧的前导码) 第二部分:勤思教育计算机教研组整理2010年计算机考研答案真题 第一题:选择题答案: 1-5 D C B C B 6-10 A A B A D 11-15 A D C B D 16-20 A D B A D 21-25 A D A C B 26-30 A D B B C 31-35 C B C A A 36-40 C B C A A 第二题:综合题答案 41、 (1)因为装填因子为0.7,数据总数为7,所以存储空间长度为 L = 7/0.7 = 10 因此可选T=10,构造的散列函数为 H(key) = (key*3) MOD 10 线性探测再散列函数为: Hi = ( H(key)+ di ) MOD 10 , (di = 1,2,3...9) 因此,各数据的下标为 H(7) = (7*3) MOD 10 = 1 H(8) = (8*3) MOD 10 = 4 H(30) = (30*3) MOD 10 = 0 H(11) = (11*3) MOD 10 = 3 H(18) = (18*3) MOD 10 = 4 H1 = ( H(18) +1) MOD 10 = 5 H(9) = (9*3) MOD 10 = 7 H(14) = (14*3) MOD 10 = 2 所构造的散列表如下: 0 30 1 7 2 14 3 11 4 8 5 18 6 7 9 8 9 (2)查找成功的平均查找长度为: ASL1 = (1+1+1+1+2+1+1)/7 = 8/7 查找不成功的平均查找长度为: ASL2 =(7+6+5+4+3+2+1+2+1+1) = 3.2 42、 (1)建立一个可以放下p个整数的辅助队列,将数组R中的前p个整数依次进入辅助队列,将R中后面的n-p个整数依次前移p个位置,将辅助队列中的数据依次出队,依次放入R中第n-p个整数开始的位置。 (2)使用c语言描述算法如下: void Shift(int *pR, int n, int p) //pR是指向数组R的指针,n为存放的整数个数, //p为循环左移的个数 { int temp[p]; // 辅助数组,存放要移出的整数。 int i=0; while(i temp[i] = pR[i]; i++; } i = 0; while(i < n-p) { //将R中从第p个整数开始的整数前移p个位置。 pR[i] = pR[p+i]; i++; } i = 0; while(i < p) { //将辅助数组中的p个数据放到R中第n-p个数据的后面。 pR[n-p+i] = temp[i]; i++; } return; } (3)所设计的算法的时间复杂度为O(n),空间复杂度为O(p) 43、 (1)OP字段占4个bit位,因此该指令系统最多有2^4 = 16条指令;Rs/Rd为3个bit,因此最多有2^3 = 8 个通用寄存器;128K/2 = 64k = 2^16,所以存储器地址寄存器位数至少为16位,(勤思考研)指令字长度为16位,所以存储器数据寄存器至少为16位。 (2)因为Rn是16位寄存器,所以可以寻址的目标地址范围是64K,即整个存储器空间。 (3)对应的机器码是230DH,该指令执行后R5的内容变为5679H,地址5678H的内容变为68AC。 44.解题思路: (1)cache总容量等于cache每一行的容量乘以cache的行数。(勤思考研)大家需要注意的是,本题cache总容量分别等于数据cache和指令cache的总和。 (2)分别计算出A[0][31]A[1][1]的地址的值,然后根据直接映射方式除以cache行的大小,与cache行数求余,所得的余数就是所映射的cache块。 (3)cache的命中率等于访问cache的次数除以cache的次数加上访问内存的次数。本题通过计算得 知,命中率高的计算速度快。 45、 (1)2KB = 2*1024*8bit = 16384bit。因此可以使用位图法进行磁盘块空闲状态管理,(勤思考研)每1bit表示一个磁盘块是否空闲。 (2)每分钟6000转,转一圈的时间为0.01s,通过一个扇区的时间为0.0001s。 根据CSCAN算法,被访问的磁道号顺序为100 120 30 50 90,因此,寻道用去的总时间为:(20 + 90 + 20 + 40)* 1ms = 170ms 总共要随机读取四个扇区,用去的时间为:(0.01*0.5 + 0.0001)*4 = 0.0204s = 20.4ms 所以,读完这个扇区点共需要 170ms + 20.4ms = 192.4ms。 46、 (1)17CAH 转换为二进制为:0001 0111 1100 1010, 页的大小为1KB,(勤思考研)所以页内偏移为10位,于是前6位是页号,所以其页号为0001 01,转换为10进制为5,所以,17CA对应的页号为5。 (2)若采用先进先出置换算法,则被置换出的页号对应的页框号是7,因此对应的二进制物理地址为:0001 1111 1100 1010,转换为16进制位的物理地址为1FCAH。 (3)若采用时钟算法,且当前指针指向2号页框,则第一次循环时,访问位都被置为0,在第二次循环时,将选择置换2号页框对应的页,因此对应的二进制物理地址为:0000 1011 1100 1010,转换为16进制物理地址为0BCAH。 47、(1)当甲乙两台主机同时向对方发送数据时,两台主机均检测到冲突的时间最短: Tmin = 1KM/200000KM/S*2 = 10us 当一台主机发送的数据就要到达另一台主机时,另一台主机才发送数据,(勤思考研)两台主机均检测到冲突的时间最长: Tmax = 2KM/200000KM/S*2 = 20us (2)主机甲发送一帧数据所需的时间为: T1 = 1518B/10Mbps = 1.2144ms 数据在传输过程中所需的时间: T2 = 2KM/200000KM/S = 0.01ms 因此,主机甲的有效数据传输速率为: V= 10Mbps*(T1/(T1+T2)) = 10Mbps*(1.2144ms/(1.2144ms+0.01ms) )= 9.92Mbps 因篇幅问题不能全部显示,请点此查看更多更全内容