计算机专业基础2017年南京航空航天大学硕士研究生考试真题
南京航空航天大学
2017年硕士研究生入学考试初试试题(
科目代码: 科目名称:
829
计算机专业基础
A卷 )
分
满分: 150
注意: ①认真阅读答题纸上的注意事项;②所有答案必须写在答题纸上,写在本试题纸或草稿纸上均无效;③本试题纸须随答题纸一起装入试题袋中交回! 数据结构部分(50分)
1.(10分)为一个家谱管理程序设计一种数据结构,以一个四代人,11个家庭成员为例,(A有3个孩子A1、A2、A3;A1有2个孩子A11、A12;A2无子,A3有3个孩子A31、A32、A33;A11有1个孩子A111;A32有1个孩子A321;其余尚无子),画出家谱示意图,给出所设计的存储结构示意图,并给出在该存储结构上输出第k代所有人员的算法思想。
2.(10分)已知输入数据序列为 (58,68,42,10,88,32,70,52,55,46 ),给出建立3阶B-树示意图,再给出删除55,70后的B-树。
3.(10分)试用Dijkstra算法,求下图中从V1到其余各顶点的最短路径,给出实现算法所用的数据结构和求解过程中每一步的状态。
4.(10分)设A、B为递减有序(元素值为整型)的单链表,编写函数,利用原结点将它们合并成一个递增有序的单链表,相同元素值只保留一个结点。先给出算法思想,再写出相应代码。
5.(10分)设有n个学生成绩(0-100整数)的顺序结构线性表L,编写函数,将该线性表中调整为成绩及格(大于等于60)在不及格之前,要求T(n)=O(n), S(n)=O(1)。先给出算法思想,再写出相应代码。
科目代码:829科目名称:计算机专业基础 第1页 共6页
梦想不会辜负每一个努力的人
操作系统部分(50分)
6. (16分) 简答(4分/题)
(1) 系统型线程和用户型线程有何区别? (2)分段式系统和分页式系统有何区别?
(3)引入缓冲的目的是什么,有哪些常见的缓冲模式? (4)SPOOLING技术如何实现,在操作系统中起何作用?
7. (7分) 设有三道作业,它们的提交时间及执行时间由下表给出:
作业号 1 2 3 提交时间 8.5 9.2 9.4 执行时间 2.0 1.6 0.5 试计算在单道程序环境下,采用先来先服务调度算法和最短作业优先调度算法时的平均周转时间
8. (9分) 某系统有A、B、C、D四类资源可供五个进程P1、P2、P3、P4、P5共享。系统共有这四类资源为:A类3个、B类14个、C类12个、D类12个。进程对资源的需求和分配情况如下:
进程 已占有资源 最大需求数 A B C D A B C D P1 P2 P3 P4 P5 0 0 1 2 1 0 0 0 1 3 5 4 0 6 3 2 0 0 1 4 0 0 1 2 1 7 5 0 2 3 5 6 0 6 5 2 0 6 5 6 (1)现在系统是否处于安全状态?(4分)
(2)如果进程P2提出需要A类资源0个、B类资源4个、C类资源2个和D类资源0个,系统能否去满足它的请求?(5分)
9.(9分) 某分页系统,每个页面长为1KB,某时刻该用户进程的页表如下:
科目代码:829科目名称:计算机专业基础 第2页 共6页
梦想不会辜负每一个努力的人
页号 0 1 2 3 4 5 6 物理块号 8 7 4 10 5 3 2 是否在快表 是 是 否 否 否 是 是 (1) 请写出分页系统的地址转换过程(3分)
(2)计算两个逻辑地址:0AC5H、1AC5H对应的物理地址(16进制表示)。(3分) (3)已知主存的一次存取为2us,对于快表的查询时间可以忽略,则访问上述两个逻辑地址分别耗费多少时间?(3分)
10. (9分) 一家四口人,儿子喜欢吃苹果,由父亲负责购买, 女儿喜欢吃橘子,由母亲负责购买。父亲和母亲购买水果后放到家中的抽屉里,儿子和女儿从抽屉里取出水果。假设抽屉只能容纳20个水果,同时只能一人开关, 用纪录型信号量同步父母子女四个进程。
组成原理部分(50分)
11.(10分)简答题(5分/题)
(1)计算机内部的指令和数据均以二进制信息的形式存放在存储器中,请问计算机如何从时间和空间上区别它们?
(2)为什么用算逻部件ALU和移位器能够实现定点数和浮点数的加减乘除运算? 12.(10分) 下面一段C程序用于计算数组a中各元素之和。当参数len为0时,返回值应该为0。但计算机执行该程序时,却发生了存储器访问异常。这是什么原因造成的?应该如何修改?
1 2 3 4 5 6 7 8 9
float sum_elements (float a[], unsigned len) { int i; float result = 0; }
for (i = 0; i <= len–1; i++) result += a[i]; return result;
科目代码:829科目名称:计算机专业基础 第3页 共6页
梦想不会辜负每一个努力的人
13.(15分)高级语言语句“for (i=0;i # R[$t0]←0 # R[$t1]←0 # R[$t2]←R[$t1]+ R[$s3] loop: add $t2, $t1, $s3 lw $t3, 0($t2) # R[$t3]←M[R[$t2]+0],即R[$t3]=a[i] add $s2, $s2,$t3 # R[$s2]←R[$s2]+ R[$t3] addi $t1, $t1, 8 # R[$t1]←R[$t1]+8,即R[$t1]=8*i addi $t0, $t0, 1 # R[$t0]←R[$t0]+1,即i=i+1 bne $t0, $s5, loop # if R[$t0]≠ R[$s5] then goto loop 假定这段指令存放在内存0x0800 00C0开始的一段内存中,请回答下列问题。 (1)已知$s2的编号为10010,$t3的编号为01011,指令i5的机器代码是什么?请用16进制表示。(提示:add为R-型指令,编码如图所示,其字段顺序为OP、Rs、Rt、Rd、Sh和Func) op(31:28)=000000 (R-format), func(5:0) 2-0 5-3 000 001 010 011 100 (2)根据对汇编代码的分析可知数组a的每个数组元素占几个字节? (3)若N=10,则上述程序段执行过程中共执行了多少条指令?若单周期处理器的时钟频率为2GHz,则上述程序段(N=10)在该单周期处理器中执行时的CPU时间为多少? 14.(15分)假定一个计算机系统中有一个TLB和一个L1 data cache。该系统按字节编址,虚拟地址16位,物理地址13位;页大小为256B,TLB为四路组相联,共有16个页表项; 科目代码:829科目名称:计算机专业基础 第4页 共6页 000 001 010 011 100 shift left jump mfhi mult add jalr mthi multu addu shift right mflo div sub sra mlto divu subu sllv syscall and 梦想不会辜负每一个努力的人 L1 data cache采用直接映射方式,块大小为4B,共16行。在系统运行到某一时刻时,TLB、页表和L1 data cache中的部分内容(用十六进制表示)如下表(a),(b),(c)所示: 组号/标记/页框号/有效位/标记/页框号/有效位/标记/页框号/有效位/标记/页框号/有效位 0 03 1 03 2 02 3 01 – 2D – 11 0 1 0 1 09 02 01 63 0D – 19 0D 1 0 1 1 00 01 06 0A – 13 – 34 0 1 0 1 01 0A 03 72 02 – – – 1 0 0 0 (a) TLB(四路组相联)的四组/16个页表项 虚页号/页框号/有效位 行索引/ 标记/ 有效位/ 字节3/ 字节2/ 字节1/ 字节0 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F 08 03 14 02 – 16 – 07 13 17 09 – 19 – 11 0D 1 1 1 1 0 1 0 1 1 1 1 0 1 0 1 1 0 1 2 3 4 5 6 7 8 9 A B C D E F 19 15 1B 36 32 0D – 16 24 2D 2D – 12 16 65 14 1 0 1 0 1 1 0 1 1 0 1 0 1 1 1 0 12 – 03 – 23 46 – 12 23 – 43 – 76 A3 2D – 56 – 45 – 34 67 – 54 62 – 62 – 83 F4 4A – C9 – 12 – C2 23 – 65 12 – 23 – 21 23 45 – AC – CD – 2A 3D – DC 3A – C3 – 35 11 55 – (b) 部分页表(开始的16项) (c) L1 data cache:直接映射,共16行,块大小为4B (1)虚拟地址中哪几位表示虚拟页号?哪几位表示页内偏移量?虚拟页号中哪几位表示TLB标记?哪几位表示TLB索引? 科目代码:829科目名称:计算机专业基础 第5页 共6页 梦想不会辜负每一个努力的人 (2)物理地址中哪几位表示物理页号?哪几位表示页内偏移量? (3)主存(物理)地址如何划分成标记字段、行索引字段和块内地址字段? (4)CPU从地址067AH中取出的short型值(16bit-大端方式)为多少?说明CPU读取地址067AH中内容的过程。 科目代码:829科目名称:计算机专业基础 第6页 共6页 因篇幅问题不能全部显示,请点此查看更多更全内容