2017年计算机学科专业基础综合试题

科目组合

数据结构 、计算机组成原理 、操作系统 、计算机网络

01: 50: 37
答题卡
得分 107/150
答对题目数 37/47
评价

答题情况分析报告

正确: 37
错误: 10
未答: 0
总分: 107/150
正确率 78.7%
第1题 数据结构 单选题 题目链接

下列函数的时间复杂度是( )。

int func(int n) { 
   int i = 0, sum = 0;
   while(sum < n) sum += ++i;
   return i;
}

A. O(log⁡n)

B. O(n^(1/2))

C. O(n)

D. O(nlog⁡n)

正确答案:B 你的答案: 正确 正确率:73%
点击此处查看本题答案

第2题 数据结构 单选题 题目链接

下列关于栈的叙述中,错误的是( )。

(1)采用非递归方式重写递归程序时必须使用栈
(2)函数调用时,系统要用栈保存必要信息
(3)只要确定了入栈次序,即可确定出栈次序
(4)栈是一种受限的线性表,允许在其两端进行操作

A、仅(1)
B、仅(1)、(2)、(3)
C、仅(1)、(3)、(4)
D、仅(2)、(3)、(4)

正确答案:C 你的答案: 正确 正确率:85%
点击此处查看本题答案

第3题 数据结构 单选题 题目链接

适用于压缩存储稀疏矩阵的两种存储结构是()

A.三元组表和十字链表

B.三元组表和邻接矩阵

C.十字链表和二叉链表

D.邻接矩阵和十字链表

正确答案:A 你的答案: 正确 正确率:87%
点击此处查看本题答案

第4题 数据结构 单选题 题目链接

要使一颗非空二叉树的先序序列与中序序列相同,其所有非叶节点须满足的条件是()

A.只有左子树

B.只有右子树

C.结点的度均为1

D.结点的度均为2

正确答案:B 你的答案: 正确 正确率:88%
点击此处查看本题答案

第5题 数据结构 单选题 题目链接

已知一颗二叉树的树形如下图所示,其后序序列为e,a,c,b,d,g,f,树中与结点a同层的结点是()

A.c     B.d

C.f     D.g

正确答案:B 你的答案: 正确 正确率:94%
点击此处查看本题答案

第6题 数据结构 单选题 题目链接

已知字符集{a, b, c, d, e, f, g, h},若各字符的哈夫曼编码依次是0100, 10, 0000, 0101, 001, 011, 11, 0001,则编码序列0100011001001011110101的译码结果是( )。

A. a c g a b f h

B. a d b a g b b

C. a f b e a g d

D. a f e e f g d

正确答案:D 你的答案: 正确 正确率:99%
点击此处查看本题答案

第7题 数据结构 单选题 题目链接

已知无向图G含有16条边,其中度为4的顶点个数为3,度为3的顶点个数为4,其他顶点的度均小于3。图G所含的顶点个数至少是()

A.10     B.11

C.13     D.15

正确答案:B 你的答案: 正确 正确率:86%
点击此处查看本题答案

第8题 数据结构 单选题 题目链接

下列二叉树中,可能成为折半查找判定树(不含外部结点)的是()

正确答案:A 你的答案: 正确 正确率:67%
点击此处查看本题答案

第9题 数据结构 单选题 题目链接

下列应用中,适合使用B+树的是()

A.编译器中的词法分析

B.关系数据库系统中的索引

C.网络中的路由表快速查找

D.操作系统的磁盘空闲块管理

正确答案:B 你的答案: 正确 正确率:76%
点击此处查看本题答案

第10题 数据结构 单选题 题目链接

在内部排序时,若选择了归并排序而没有选择插入排序,则可能的理由是()

  1. 归并排序的程序代码更短
  2. 归并排序的占用空间更少
  3. 归并排序的运行效率更高

A.仅2

B.仅3

C.仅1、2

D.仅1、3

正确答案:B 你的答案: 正确 正确率:79%
点击此处查看本题答案

第11题 数据结构 单选题 题目链接

下列排序方法中,若将顺序存储更换为链式存储,则算法的时间效率会降低的是()

1.插入排序  2.选择排序  3.起泡排序  4.希尔排序  5.堆排序

A.仅1、2

B.仅2、3

C.仅3、4

D.仅4、5

正确答案:D 你的答案: 正确 正确率:67%
点击此处查看本题答案

第12题 计算机组成原理 单选题 题目链接

假定计算机M1和M2具有相同的指令集体系结构(ISA),主频分别为1.5GHz和1.2GHz。在M1和M2上运行某基准程序P,平均CPI分别为2和1,则程序P在M1和M2上运行时间的比值是( )。

A. 0.4

B. 0.625

C. 1.6

D. 2.5

正确答案:C 你的答案: 正确 正确率:82%
点击此处查看本题答案

第13题 计算机组成原理 单选题 题目链接

某计算机主存按字节编址,由4个64M×8位的DRAM芯片采用交叉编址方式构成,并与宽度为32位的存储器总线相连,主存每次最多读写32位数据。若double型变量x的主存地址为804001AH,则读取x需要的存储周期数是( )。

A. 1

B. 2

C. 3

D. 4

正确答案:C 你的答案: B 正确率:55%
点击此处查看本题答案

第14题 计算机组成原理 单选题 题目链接

某C语言程序段如下:

for (i=0; i<=9; i++) {
    temp=1;
    for (j=0; j<=i; j++) temp*=a[j];
    sum+=temp;
}

下列关于数组a的访问局部性的描述中,正确的是( )。

A. 时间局部性和空间局部性皆有

B. 无时间局部性,有空间局部性

C. 有时间局部性,无空间局部性

D. 时间局部性和空间局部性皆无

正确答案:A 你的答案: 正确 正确率:56%
点击此处查看本题答案

第15题 计算机组成原理 单选题 题目链接

下列寻址方式中,最适合按下标顺序访问一维数组元素的是

A.相对寻址    B.寄存器寻址    C.直接寻址   D.变址寻址

正确答案:D 你的答案: 正确 正确率:75%
点击此处查看本题答案

第16题 计算机组成原理 单选题 题目链接

某计算机按字节编址,指令字长固定且只有两种指令格式,其中三地址指令29条,二地址指令107条,每个地址字段为6位,则指令字长至少应该是( )。

A. 24位

B. 26位

C. 28位

D. 32位

正确答案:A 你的答案: B 正确率:80%
点击此处查看本题答案

第17题 计算机组成原理 单选题 题目链接

下列关于超标量流水线特性的叙述中,正确的是( )。

Ⅰ. 能缩短流水线功能段的处理时间

Ⅱ. 能在一个时钟周期内同时发射多条指令

Ⅲ. 能结合动态调度技术提高指令执行并行性

A. 仅Ⅱ

B. 仅Ⅰ、Ⅲ

C. 仅Ⅱ、Ⅲ

D. Ⅰ、Ⅱ和Ⅲ

正确答案:C 你的答案: 正确 正确率:72%
点击此处查看本题答案

第18题 计算机组成原理 单选题 题目链接

下列关于主存储器(MM)和控制存储器(CS)的叙述中,错误的是( )。

A. MM在CPU外,CS在CPU内

B. MM按地址访问,CS按内容访问

C. MM存储指令和数据,CS存储微指令

D. MM用RAM和ROM实现,CS用ROM实现

正确答案:B 你的答案: 正确 正确率:65%
点击此处查看本题答案

第19题 计算机组成原理 单选题 题目链接

下列关于指令流水线数据通路的叙述中,错误的是( )。

A. 包含生成控制信号的控制部件

B. 包含算术逻辑运算部件(ALU)

C. 包含通用寄存器组和取指部件

D. 由组合逻辑电路和时序逻辑电路组合而成

正确答案:A 你的答案: 正确 正确率:52%
点击此处查看本题答案

第20题 计算机组成原理 单选题 题目链接

下列关于多总线结构的叙述中,错误的是( )。

A. 靠近CPU的总线速度较快

B. 存储器总线可支持突发传送方式

C. 总线之间须通过桥接器相连

D. PCI-Express×16采用并行传输方式

正确答案:D 你的答案: 正确 正确率:61%
点击此处查看本题答案

第21题 计算机组成原理 单选题 题目链接

I/O指令实现的数据传送通常发生在( )。

A. I/O设备和I/O端口之间

B. 通用寄存器和I/O设备之间

C. I/O端口和I/O端口之间

D. 通用寄存器和I/O端口之间

正确答案:D 你的答案: 正确 正确率:62%
点击此处查看本题答案

第22题 计算机组成原理 单选题 题目链接

下列关于多重中断系统的叙述中,错误的是( )。

A. 在一条指令执行结束时响应中断

B. 中断处理期间CPU处于关中断状态

C. 中断请求的产生与当前指令的执行无关

D. CPU通过采样中断请求信号检测中断请求

正确答案:B 你的答案: 正确 正确率:68%
点击此处查看本题答案

第23题 操作系统 单选题 题目链接

假设4个作业到达系统的时刻和运行时间如下表所示。

系统在t=2时开始作业调度。若分别采用先来先服务和短作业优先调度算法,则选中的作业分别是

A. J2、J3

B. J1、J4

C. J2、J4

D. J1、J3

正确答案:D 你的答案: 正确 正确率:91%
点击此处查看本题答案

第24题 操作系统 单选题 题目链接

执行系统调用的过程包括如下主要操作:

①返回用户态         ②执行陷入(trap)指令

③传递系统调用参数   ④执行相应的服务程序

正确的执行顺序是( )。

A. ②→③→①→④                    B. ②→④→③→①

C. ③→②→④→①                    D. ③→④→②→①

正确答案:C 你的答案: 正确 正确率:75%
点击此处查看本题答案

第25题 操作系统 单选题 题目链接

某计算机按字节编址,其动态分区内存管理采用最佳适应算法,每次分配和回收内存后都对空闲分区链重新排序。当前空闲分区信息如下表所示。

回收起始地址为60K、大小为140KB的分区后,系统中空闲分区的数量、空闲分区链第一个分区的起始地址和大小分别是( )。

A. 3、20K、380KB

B. 3、500K、80KB

C. 4、20K、180KB

D. 4、500K、80KB

正确答案:B 你的答案: 正确 正确率:59%
点击此处查看本题答案

第26题 操作系统 单选题 题目链接

某文件系统的簇和磁盘扇区大小分别为1KB和512B。若一个文件的大小为1026B,则系统分配给该文件的磁盘空间大小是( )。

A. 1026B

B. 1536B

C. 1538B

D. 2048B

正确答案:D 你的答案: 正确 正确率:79%
点击此处查看本题答案

第27题 操作系统 单选题 题目链接

下列有关基于时间片的进程调度的叙述中,错误的是( )。

A. 时间片越短,进程切换的次数越多,系统开销也越大

B. 当前进程的时间片用完后,该进程状态由执行态变为阻塞态

C. 时钟中断发生后,系统会修改当前进程在时间片内的剩余时间

D. 影响时间片大小的主要因素包括响应时间、系统开销和进程数量等

正确答案:B 你的答案: 正确 正确率:97%
点击此处查看本题答案

第28题 操作系统 单选题 题目链接

与单道程序系统相比,多道程序系统的优点是(  )

Ⅰ.CPU利用率高

Ⅱ.系统开销小

Ⅲ.系统吞吐量大

Ⅳ.I/O设备利用率高

A.仅Ⅰ、Ⅲ            B. 仅Ⅰ、Ⅳ

C. 仅Ⅱ 、Ⅲ          D. 仅Ⅰ、Ⅲ、Ⅳ

正确答案:D 你的答案: 正确 正确率:85%
点击此处查看本题答案

第29题 操作系统 单选题 题目链接

下列选项中,磁盘逻辑格式化程序所做的工作是( )。

Ⅰ. 对磁盘进行分区

Ⅱ. 建立文件系统的根目录

Ⅲ. 确定磁盘扇区校验码所占位数

Ⅳ. 对保存空闲磁盘块信息的数据结构进行初始化

A. 仅Ⅱ

B. 仅Ⅱ、Ⅳ

C. 仅Ⅲ、Ⅳ

D. 仅Ⅰ、Ⅱ、Ⅳ

正确答案:B 你的答案: 正确 正确率:46%
点击此处查看本题答案

第30题 操作系统 单选题 题目链接

某文件系统中,针对每个文件,用户类别分为4类:安全管理员、文件主、文件主的伙伴、其他用户;访问权限分为5种:完全控制、执行、修改、读取、写入。若文件控制块中用二进制位串表示文件权限,为表示不同类别用户对一个文件的访问权限,则描述文件权限的位数至少应为( )。

A. 5

B. 9

C. 12

D. 20

正确答案:D 你的答案: 正确 正确率:66%
点击此处查看本题答案

第31题 操作系统 单选题 题目链接

若文件f1的硬链接为f2,两个进程分别打开f1和f2,获得对应的文件描述符为fd1和fd2,则下列叙述中,正确的是( )。

Ⅰ. f1和f2的读写指针位置保持相同

Ⅱ. f1和f2共享同一个内存索引结点

Ⅲ. fd1和fd2分别指向各自的用户打开文件表中的一项

A. 仅Ⅲ

B. 仅Ⅱ、Ⅲ

C. 仅Ⅰ、Ⅱ

D. Ⅰ、Ⅱ和Ⅲ

正确答案:B 你的答案: 正确 正确率:63%
点击此处查看本题答案

第32题 操作系统 单选题 题目链接

系统将数据从磁盘读到内存的过程包括以下操作:

① DMA控制器发出中断请求

② 初始化DMA控制器并启动磁盘

③ 从磁盘传输一块数据到内存缓冲区

④ 执行“DMA结束”中断服务程序

正确的执行顺序是( )。

A. ③→①→②→④

B. ②→③→①→④

C. ②→①→③→④

D. ①→②→④→③

正确答案:B 你的答案: 正确 正确率:66%
点击此处查看本题答案

第33题 计算机网络 单选题 题目链接

假设OSI参考模型的应用层欲发送400B的数据(无拆分),除物理层和应用层之外,其他各层在封装PDU时均引入20B的额外开销,则应用层数据传输效率约为( )。

A. 80%

B. 83%

C. 87%

D. 91%

正确答案:A 你的答案: 正确 正确率:87%
点击此处查看本题答案

第34题 计算机网络 单选题 题目链接

若信道在无噪声情况下的极限数据传输速率不小于信噪比为30dB条件下的极限数据传输速率,则信号状态数至少是( )。

A. 4

B. 8

C. 16

D. 32

正确答案:D 你的答案: C 正确率:76%
点击此处查看本题答案

第35题 计算机网络 单选题 题目链接

在下图所示的网络中,若主机H发送一个封装访问Internet的IP分组的IEEE 802.11数据帧F,则帧F的地址1、地址2和地址3分别是( )。

A. 00-12-34-56-78-9a, 00-12-34-56-78-9b, 00-12-34-56-78-9c

B. 00-12-34-56-78-9b, 00-12-34-56-78-9a, 00-12-34-56-78-9c

C. 00-12-34-56-78-9b, 00-12-34-56-78-9c, 00-12-34-56-78-9a

D. 00-12-34-56-78-9a, 00-12-34-56-78-9c, 00-12-34-56-78-9b

正确答案:B 你的答案: 正确 正确率:69%
点击此处查看本题答案

第36题 计算机网络 单选题 题目链接

下列IP地址中,只能作为IP分组的源IP地址但不能作为目的IP地址的是( )。

A. 0.0.0.0

B. 127.0.0.1

C. 20.10.10.3

D. 255.255.255.255

正确答案:A 你的答案: 正确 正确率:81%
点击此处查看本题答案

第37题 计算机网络 单选题 题目链接

直接封装RIP、OSPF、BGP报文的协议分别是( )。

A. TCP、UDP、IP

B. TCP、IP、UDP

C. UDP、TCP、IP

D. UDP、IP、TCP

正确答案:D 你的答案: 正确 正确率:73%
点击此处查看本题答案

第38题 计算机网络 单选题 题目链接

若将网络21.3.0.0/16划分为128个规模相同的子网,则每个子网可分配的最大IP地址个数是( )。

A. 254

B. 256

C. 510

D. 512

正确答案:C 你的答案: 正确 正确率:92%
点击此处查看本题答案

第39题 计算机网络 单选题 题目链接

若甲向乙发起一个TCP连接,最大段长MSS=1KB,RTT=5ms,乙开辟的接收缓存为64KB,则甲从连接建立成功至发送窗口达到32KB,需经过的时间至少是( )。

A. 25 ms

B. 30 ms

C. 160 ms

D. 165 ms

正确答案:A 你的答案: 正确 正确率:68%
点击此处查看本题答案

第40题 计算机网络 单选题 题目链接

下列关于FTP协议的叙述中,错误的是( )。

A. 数据连接在每次数据传输完毕后就关闭

B. 控制连接在整个会话期间保持打开状态

C. 服务器与客户端的TCP 20端口建立数据连接

D. 客户端与服务器的TCP 21端口建立控制连接

正确答案:C 你的答案: 正确 正确率:85%
点击此处查看本题答案

第41题 数据结构 综合题 题目链接

(15分)请设计一个算法,将给定的表达式树(二叉树)转换为等价的中缀表达式(通过括号反映操作符的计算次序)并输出。例如,当下列两棵表达式树作为算法输入时:

输出的中缀表达式分别为 (a+b)∗(c∗(−d)) 和 (a∗b)+(−(c−d)) 。

二叉树结点的定义如下:

typedef struct node{ 
    char data[10];   // 存储操作数或操作符
    struct node *left, *right;     
}BTree;

要求:

⑴ 给出算法的基本设计思想。(5分)

⑵ 根据设计思想,采用C或C++语言描述算法,关键之处给出注释。(10分)

你的答案:

1)通过二叉树的中序遍历,可以得出他的中缀表达式。如果一个结点有孩子且不是根节点,那就先输出“(”再访问他的左孩子。当一个结点没有孩子,输出该节点。接下来再遍历他的右子树。当右子树遍历到最后一个结点,说明这一段表达式结束,输出“)”。

2)

void expressionMid(BTree T, int depth){
    if(T == NULL) return;    //空树返回
    if(depth > 0 && T->left != NULL || T->right != NULL)    printf("(");
    expressionMid(T->left, depth+1);
    printf(T->data);
    expressionMid(T->right, depth+1);
    if(depth > 0 && T->left != NULL || T->right != NULL)    printf(")");


}

评分及理由

(1)得分及理由(满分5分)

得分:3分

理由:学生基本理解了中序遍历的思想,提到了通过中序遍历输出表达式,并考虑了括号的添加。但是描述不够准确和完整:
- 没有明确说明根节点不需要加括号
- 对括号添加条件的描述比较模糊("不是根节点"、"当右子树遍历到最后一个结点"等表述不准确)
- 没有清晰说明深度参数的作用
基本思路正确但表达不够严谨,扣2分。

(2)得分及理由(满分10分)

得分:6分

理由:代码实现了基本的中序遍历框架,但存在以下逻辑错误:
- 括号添加条件有误:`depth > 0 && T->left != NULL || T->right != NULL` 存在运算符优先级问题,应该是 `(depth > 0 && (T->left != NULL || T->right != NULL))`
- 缺少对叶子节点的特殊处理,标准答案中对叶子节点直接输出,不添加括号
- 函数参数应该是 `BTree*` 而不是 `BTree`
- `printf(T->data)` 语法错误,应该是 `printf("%s", T->data)`
- 缺少主调用函数
代码框架基本正确,但存在多处逻辑错误和语法问题,扣4分。

题目总分:3+6=9分

点击此处查看本题答案

第42题 数据结构 综合题 题目链接

(8分)使用Prim(普里姆)算法求带权连通图的最小(代价)生成树(MST)。请回答下列问题。

⑴ 对下列图G,从顶点A开始求G的MST,依次给出按算法选出的边。(4分)

⑵ 图G的MST是唯一的吗?(2分)

⑶ 对任意的带权连通图,满足什么条件时,其MST是唯一的?(2分)

你的答案:

1) A->D, D->E, E->C, C->B

2)是的

3)当一个连通图中环路没有相同权值的时候MST唯一。


评分及理由

(1)得分及理由(满分4分)

学生给出的边序列为:A→D, D→E, E→C, C→B。这与标准答案(A,D)、(D,E)、(C,E)、(B,C)在边的选择上完全一致,且顺序也正确。虽然学生使用了箭头符号表示,但表达的含义与标准答案相同。因此本题得满分4分。

(2)得分及理由(满分2分)

学生回答"是的",表示认为图G的MST是唯一的,这与标准答案一致。因此本题得满分2分。

(3)得分及理由(满分2分)

学生回答"当一个连通图中环路没有相同权值的时候MST唯一",这与标准答案"当带权连通图的任意一个环中所包含的边的权值均不相同时,其MST是唯一的"在含义上是一致的。虽然表述略有不同,但核心思想正确。因此本题得满分2分。

题目总分:4+2+2=8分

点击此处查看本题答案

第43题 计算机组成原理 综合题 题目链接

(13分)已知\[ f(n)=\sum_{i = 0}^{n}2^{i}=2^{n + 1}-1=\underbrace{11\cdots1}_{n + 1位}\text{B} \] ,计算f(n)的C语言函数f1如下:

int f1(unsigned n)
{ 
    int sum=1, power=1;
    for(unsigned i=0; i<= n -1; i ++)
    { 
        power * = 2;
        sum += power;
    }
    return sum ;
}

将f1中的int都改为float,可得到计算f(n)的另一个函数f2。假设unsigned和int型数据都占32位,float采用IEEE754单精度标准。请回答下列问题。

(1) 当n=0时,f1会出现死循环,为什么?若将f1中的变量i和n都定义为int型,则f1是否还会出现死循环?为什么?(4分)

(2) f1(23)和f2(23)的返回值是否相等?机器数各是什么(用十六进制表示)?(3分)

(3) f1(24)和f2(24)的返回值分别为33554431和33554432.0,为什么不相等?(1分)

(4) f(31)= 2^32−1 ,而f1(31)的返回值却为-1,为什么?若使f1(n)的返回值与f(n)相等,则最大的n是多少?(2分)

(5) f2(127)的机器数为7F80 0000H,对应的值是什么?若使f2(n)的结果不溢出,则最大的n是多少?若使f2(n)的结果精确(无舍入),则最大的n是多少?(3分)

你的答案:

1)n=0时,f1会出现死循环,因为i是不断递增的,n-1所表示的是最大的无符号整数,无论怎么加都不可能超过他,所以会死循环。如果变成有符号整数,不会死循环,因为出现负数,直接就结束了。

2)float是浮点数,最大的表示范围是2^23,刚好不越界,所以相同。机器数分别是:00FF FFFFH和4B7F FFFFH

3) float在32位的时候最多有23位尾数,f2(24)已经溢出。

4)总共有32位,f1(31)则是有32个1,符号位是1,因此是负数。最大的n是30.

5)f2是float,尾数全为0,符号位是0,表示正无穷。最大的n是23。


评分及理由

(1)得分及理由(满分4分)

学生正确解释了n=0时死循环的原因:无符号整数n-1为最大值,条件永真。同时正确指出改为int后不会死循环,因为n-1=-1,条件不成立。但未明确说明无符号比较和带符号比较的区别,解释略显简略。扣1分。

得分:3分

(2)得分及理由(满分3分)

学生正确指出f1(23)和f2(23)返回值相等,并给出了正确的机器数。但解释部分“float最大的表示范围是2^23”表述不准确(应为23位尾数),不过不影响核心结论。扣0.5分。

得分:2.5分

(3)得分及理由(满分1分)

学生提到“float在32位时最多有23位尾数”正确,但将现象归因于“溢出”不准确(实际是舍入导致数值增大)。扣0.5分。

得分:0.5分

(4)得分及理由(满分2分)

学生正确解释f1(31)返回-1的原因(32位1解释为负数),并正确给出最大n=30。答案完整准确。

得分:2分

(5)得分及理由(满分3分)

学生正确解释7F80 0000H为正无穷,但未说明阶码全1、尾数全0的格式要求。第二问最大n=23错误(应为126),第三问最大n=23正确。第二问扣1分,第三问给满分。

得分:2分

题目总分:3+2.5+0.5+2+2=10分

点击此处查看本题答案

第44题 计算机组成原理 综合题 题目链接

(10分)在按字节编址的计算机M上,题43中f1的部分源程序(阴影部分)与对应的机器级代码(包括指令的虚拟地址)如下图所示。

    int f1(unsigned n)
1   00401020 55         push ebp
    ...      ...        ...
        for (unsigned i = 0; i <= n-1; i++)
    ...      ...        ...
20  0040105E 39 4D F4   cmp dword ptr [ebp-0Ch],ecx
    ...      ...        ...
        { power *= 2;
    ...      ...        ...
23  00401066 D1 E2      shl edx,1
    ...      ...        ...
        return sum;
    ...      ...        ...
35  0040107F C3         ret

其中,机器级代码行包括行号、虚拟地址、机器指令和汇编指令。

请回答下列问题。

(1) 计算机M是RISC还是CISC?为什么?(2分)

(2) f1的机器指令代码共占多少字节?要求给出计算过程。(2分)

(3) 第20条指令cmp通过i减n-1实现对i和n-1的比较。执行f1(0)过程中,当i=0时,cmp指令执行后,进/借位标志CF的内容是什么?要求给出计算过程。(3分)

(4) 第23条指令shl通过左移操作实现了power*2运算,在f2中能否也用shl指令实现power*2?为什么?(3分)

你的答案:

1)CICS,因为指令长度不同长度

2)

3)0

4)不能,因为f2是float浮点数,不能通过简单的位移进行计算。


评分及理由

(1)得分及理由(满分2分)

得2分。学生正确判断为CISC,理由"指令长度不同"符合标准答案中"指令长短不一"的描述,虽然表述不够完整但核心观点正确。

(2)得分及理由(满分2分)

得0分。学生未给出任何计算过程,也未得出具体字节数,完全缺失答案内容。

(3)得分及理由(满分3分)

得0分。学生仅给出结果"0",但正确答案应为1。没有计算过程,且结果错误,属于逻辑错误。

(4)得分及理由(满分3分)

得2分。学生正确判断"不能",理由"f2是float浮点数,不能通过简单的位移进行计算"基本正确,但解释不够详细,未提及阶码部分和无最高有效数位等关键点。

题目总分:2+0+0+2=4分

点击此处查看本题答案

第45题 操作系统 综合题 题目链接

(7分)假定题44给出的计算机M采用二级分页虚拟存储管理方式,虚拟地址格式如下:

页目录号(位)页表索引(位)页内偏移量(位)页目录号(10位)页表索引(10位)页内偏移量(12位)

请针对题43的函数f1

int f1(unsigned n) { 
    int sum=1, power=1;
    for (unsigned i=0; i<=n-1; i++) { 
        power*=2;
        sum+=power;
    }
    return sum;
}

和题44中的机器指令代码,

    int f1(unsigned n)
1   00401020 55         push ebp
    ...      ...        ...
        for (unsigned i = 0; i <= n-1; i++)
    ...      ...        ...
20  0040105E 39 4D F4   cmp dword ptr [ebp-0Ch],ecx
    ...      ...        ...
        { power *= 2;
    ...      ...        ...
23  00401066 D1 E2      shl edx,1
    ...      ...        ...
        return sum;
    ...      ...        ...
35  0040107F C3         ret

回答下列问题。

(1) 函数f1的机器指令代码占多少页?(1分)

(2) 取第1条指令(push ebp)时,若在进行地址变换的过程中需要访问内存中的页目录和页表,则会分别访问它们各自的第几个表项(编号从0开始)?(2分)

(3) M的I/O采用中断控制方式。若进程P在调用f1之前通过 scanf() 获取n的值,则在执行 scanf() 的过程中,进程P的状态会如何变化?CPU是否会进入内核态?(4分)

你的答案:

1)

2)

3)


评分及理由

(1)得分及理由(满分1分)

得分:0分

理由:学生未给出任何回答,完全空白,因此不得分。

(2)得分及理由(满分2分)

得分:0分

理由:学生未给出任何回答,完全空白,因此不得分。

(3)得分及理由(满分4分)

得分:0分

理由:学生未给出任何回答,完全空白,因此不得分。

题目总分:0+0+0=0分

点击此处查看本题答案

第46题 操作系统 综合题 题目链接

(8分)某进程中有3个并发执行的线程thread1、thread2、thread3,其伪代码如下所示。

//复数的结构类型定义
typedef struct
{
    float a;
    float b;
}cnum;
cnum x,y,z; //全局变量

//计算两个复数之和
cnum add( cnum p,cnum q)
{
    cnum s;
    s.a=p.a+q.a;
    s.b=p.b+q.b;
    return s;
}

thread1
{
    cnum w;
    w=add(x,y);
    ...
}

thread2
{
    cnum w;
    w=add(y,z);
    ...
}

thread3
{
    cnum w;
    w.a=1;
    w.b=2;
    z=add(z,w);
    y=add(y,w);
    ...
}

请添加必要的信号量和P、V(或wait()、signal())操作,要求确保线程互斥访问临界资源,并且最大程度地并发执行。

你的答案:
//复数的结构类型定义
typedef struct
{
    float a;
    float b;
}cnum;
cnum x,y,z; //全局变量

//计算两个复数之和
cnum add( cnum p,cnum q)
{
    cnum s;
    s.a=p.a+q.a;
    s.b=p.b+q.b;
    return s;
}

semaphore m_x=1, m_y=1, m_z=1;
semaphore mutex = 1;

thread1
{
    wait(mutex);
    wait(x);
    wait(y);
    cnum w;
    w=add(x,y);
    signal(x);
    signal(y);
    signal(mutex);
}

thread2
{
    wait(mutex);
    wait(z);
    wait(y);
    cnum w;
    w=add(y,z);
    signal(z);
    signal(y);
    signal(mutex);
}

thread3
{
    wait(mutex);
    wait(z);
    wait(y);
    cnum w;
    w.a=1;
    w.b=2;
    z=add(z,w);
    y=add(y,w);
    signal(z);
    signal(y);
    signal(mutex);
}

评分及理由

(1)信号量定义得分及理由(满分3分)

学生定义了m_x=1, m_y=1, m_z=1和mutex=1四个信号量。但存在以下问题:

  • m_x信号量是多余的,因为只有thread1访问x,且x是只读的
  • 使用mutex作为全局互斥锁会严重降低并发性,不符合题目"最大程度地并发执行"的要求
  • 没有按照标准答案的思路为y变量设置两个独立的互斥信号量

扣2分,得1分

(2)thread1代码得分及理由(满分1分)

thread1中:

  • 使用了不必要的全局mutex和x信号量
  • 对y的保护方式不正确
  • 没有实现thread1与thread3对y的细粒度互斥访问

扣1分,得0分

(3)thread2代码得分及理由(满分2分)

thread2中:

  • 使用了不必要的全局mutex
  • 没有正确处理对y和z的访问顺序
  • 没有实现thread2与thread3对y和z的细粒度互斥访问

扣2分,得0分

(4)thread3代码得分及理由(满分2分)

thread3中:

  • 使用了不必要的全局mutex
  • 没有正确处理对y和z的访问顺序,特别是对y的访问需要同时获得两个互斥锁
  • 没有实现与thread1和thread2的细粒度互斥

扣2分,得0分

题目总分:1+0+0+0=1分

主要问题:学生使用了粗粒度的全局互斥锁,严重降低了并发性,没有实现题目要求的"最大程度地并发执行"。同时信号量的使用存在逻辑错误,对共享变量的保护方式不正确。

点击此处查看本题答案

第47题 计算机网络 综合题 题目链接

(9分)甲乙双方均采用后退N帧协议 (GBN) 进行持续的双向数据传输,且双方始终采用捎带确认,帧长均为1000 B。 Sx,y 和 Rx,y 分别表示甲方和乙方发送的数据帧,其中:x是发送序号;y是确认序号(表示希望接收对方的下一帧序号);数据帧的发送序号和确认序号字段均为3比特。信道传输速率为100 Mbps,RTT = 0.96 ms。下图给出了甲方发送数据帧和接收数据帧的两种场景,其中 t0 为初始时刻,此时甲方的发送和确认序号均为0, t1 时刻甲方有足够多的数据待发送。

请回答下列问题。

(1) 对于图(a), t0 时刻到 t1 时刻期间,甲方可以断定乙方已正确接收的数据帧数是多少?正确接收的是哪几个帧(请用 Sx,y 形式给出)?(3分)

(2) 对于图(a),从 t1 时刻起,甲方在不出现超时且未收到乙方新的数据帧之前,最多还可以发送多少个数据帧?其中第一个帧和最后一个帧分别是哪个(请用 Sx,y 形式给出)?(3分)

(3) 对于图(b),从 t1 时刻起,甲方在不出现新的超时且未收到乙方新的数据帧之前,需要重发多少个数据帧?重发的第一个帧是哪个(请用 Sx,y 形式给出)?(2分)

(4) 甲方可以达到的最大信道利用率是多少?(1分)

你的答案:

1)4个。(S0,0), (S1,0), (S2,0), (S3,0)

2)最多还可以发送2个。第一个帧是(S4,3);最后一个是(S4,3)

3)2个

 


评分及理由

(1)得分及理由(满分3分)

学生回答4个帧(S0,0、S1,0、S2,0、S3,0),但标准答案为3个帧(S0,0、S1,0、S2,0)。在GBN协议中,甲方只能断定乙方正确接收了已被确认的帧。图中甲方收到R2,3,表示乙方期望接收序号3,说明乙方已正确接收序号0、1、2的帧,但未确认序号3。学生错误地将S3,0计入,属于逻辑错误。扣2分,得1分。

(2)得分及理由(满分3分)

学生回答最多发送2个帧,第一个和最后一个均为S4,3。标准答案为5个帧(第一个S5,2,最后一个S1,2)。GBN发送窗口大小由序号空间决定(3比特,窗口大小为7),甲方当前已发送到序号4,收到R2,3后确认序号2及之前的帧,发送窗口向前滑动,可用序号为3~7和0~1(模8),共5个帧。学生答案中帧数量、起始和结束帧均错误,且未理解窗口滑动机制。扣3分,得0分。

(3)得分及理由(满分2分)

学生回答重发2个帧,但未指定第一个重发帧。标准答案为重发3个帧(第一个S2,3)。图(b)中甲方在t1时刻收到R2,3,但之前已超时重发S2,0,表明序号2及之后的帧(S2,0、S3,0、S4,0)需重发。学生答案帧数量错误,且未给出第一个重发帧。扣2分,得0分。

(4)得分及理由(满分1分)

学生未回答此问题。扣1分,得0分。

题目总分:1+0+0+0=1分

点击此处查看本题答案

继续练习 练习历史