本文主要是介绍408近年大题真题总结(后续整理入笔记),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 题型分析
- 算法设计题
- 系统分析题
- 内存+cache题
- 虚拟内存
- PV操作
- 文件系统
- IO性能
- 计网综合
- 复习建议
题型分析
综合18-23年的真题,一套卷从前到后基本只会考这些题型
- 纯算法设计(难)
- 算法+其他知识的综合设计,或者分析
- 硬件系统分析(难)
- 内存+cache
- 虚拟内存
- PV操作(难)
- 文件系统
- IO性能计算
- 计网综合
算法设计题
题型
暴力解法
如果不追求高分(135以上),算法题可以考虑暴力解法,对于计算机科班的同学来说,只要熟悉基本数据结构的操作方法,就一定可以写出来这道题,拿到7分以上的分。
建议:
- 一般会分为三部分
- 首先是写算法思路。尽量分点,细节作答,比如邻接矩阵,你不要想当然认为考官知道度怎么求,你要告诉他你是用遍历一行非零元素个数的方式求度。
- 其次是代码。和平时写代码一样,可以声明辅助函数,除了不能导库。另外注意三思而后行,辅助变量别漏了,注释写好
- 最后可能会分析复杂度
- 纵观6年真题,这道题想拿分还是很容易的,不用担心颗粒无收
- 如果想拿高分,以科班的水平,只需要将基本的那些算法代码都背一遍就好,尤其是数组,链表,二叉树的详细操作,万变不离其宗。
- 后面第二道的算法分析题,更侧重算法广度,不要求实现,但是要求对全书的大大小小算法的特性和执行过程都有了解
- 想拿高分,最后还是要回归到基本算法的夯实,足矣
- 这道题分数波动大,放在最后一个去做,如果有时间就多想,分数还可以更高,没时间就直接暴力解。
我这里简单记录一下我的思路,都是直接对着王道书标答写的:
- 23年
- 很简单,遍历节点,对每个节点求入度出度,并做判断
- 22年
- 考察数组储存的树的中序遍历
- 判断一棵树是否为二叉搜索树(排序树),要用到递归的思想,直观来看就是L<N<R,但是你不能直接用最大值最小值来判断
- 转换思路,
二叉搜索树的中序遍历是有序的
,从中序遍历的视角来看,就是当前节点大于前面子序列的最大值
,而这个子序列就是左子树,我们只需要顺着中序遍历序列检查每一个节点是否都满足这种特性即可,不用管右边 - 因此代码按照中序递归写法,LNR,其中,L和R都是递归,而N的判断中,只会和左子树最大值(val)比较,不用记录右子树最大值
- 21年
- 这道题看着吓人,最后发现还是邻接矩阵的度计算,和23年本质一样
- 20年
- 这道题牛逼,需要自己画个图,分析一下三元组距离的决定因素
- 之后用类似于归并排序的结构写程序,每次迭代要移动的下标为数轴上最靠左的那个数的下标
- 数据复杂度同一趟归并排序
- 重点:19年
- 考察链表操作,很细腻,需要链表较强的功底,明天仔细研究一下
- 18年
- 最小的正整数,要考虑已有的最长连续正整数串,其下一个数就是我们要的数。比如1234678,从1开始的连续的串是1234,因此5就是目标数
- 已知这个串从1开始,那么其最大也就是n,因此直接用空间换时间,把符合范围的数都放到对应的位置
- 最后从头开始扫一遍,要么断在中间,要么停在结尾,即目标数的位序
系统分析题
这类题难度比较高,是计组的精华所在
这道题拿满分不容易,拿大头是没问题的,但是他考的知识很多很杂,有的硬件知识如果你遗漏了,那就真是不会做,好在这些都是边边角角
- 21年真题,侧重指令结构分析
- 1,2,考察基本指标计算
- 3,难度所在,带符号整数减法,以及带符号整数乘法(除法),其中乘法是最难的,致命问题是符号位怎么搞?这道题取巧了,因为恰好乘8可以用算数移位做,如果让你直接算怎么办呢?
- 22年真题,这道题侧重CPU内部数据通路
- 1,难点所在,现场分析标志位生成和原理,死记硬背是没用的
- 2,3,5考察数据通路和CPU设计原理
- 4,控制信号序列,注意写法要标准
- 23年真题,这道题侧重指令系统
- 1,2考察寻址方式
- 3考察数组元素的地址计算,注意edx×4,那个4是数据元素大小,不要当成一行的元素个数,这两个很容易混淆
- 4考察缺页中断?
- 关于大端和小端,一般来说都是小端,你找到一个kB长的数,看看顺序就可以验证
内存+cache题
虚拟内存
PV操作
作为科班人,我最怕的还是这道题,做不出来就颗粒无收,而当初学读者写者问题的时候,背后的逻辑一直困扰着我。
- 19年
- 以哲学家问题为模板,增加了一类资源,且要有防死锁措施
- 碗看起来是增加了限制,但是碗资源非常简单,反而不会有啥限制,能够为我所用,利用碗来限制哲学家同时进餐的上限,很妙
- 因为碗既充当了资源,要P,也充当了防死锁机制,因此放在最外面卡着
- 20年
- 经典PV思想,先V后P进行同步
- 注意点1:信号量设法,用 S A B S_{AB} SAB这种设法最直观
- 注意点2:因为进程太多,所以要简化进程写法,①使用CoBegin/CoEnd同时启动所有进程。②其中的每一条进程都用Begin/End包住,不区分名字,只需要用“操作A”,“操作B”来区分
- 21年
- 考察PV操作的实现原理以及相关底层知识
- 1,互斥原理,答案浅薄,就是因为多进程共享,才要互斥,并没有具体告诉你共享不互斥会出现什么情况(脏读之类),不过点到为止,小分别计较,先浅后深最好
- 2,这个没学过,你要自己模拟一下,防止死循环
- 3,用户无法用特权指令
- 22年
- 同20年,写法略有不同,20年没有告诉你几个进程,你可以让每一个操作对应一个进程,然后用简化方法写进程
- 22年告诉你有俩进程,并且规定了任务的归属,那就将PV穿插在每个进程的任务之间即可。同一个进程,先后顺序已经OK了,所以你只需要注意进程之间的制约即可,图可以进一步简化
- 23年
- 考察了swap指令:互斥的硬件实现,大胆猜测一下,明年要么深入考一下硬件,要么就换到理发师,之类的其他没考过的PV问题了
后续怎么复习呢,硬件这块得回忆一下,其次就是经典PV问题
文件系统
IO性能
计网综合
复习建议
- 做过的题都翻一遍
- 笔记都看一遍,注重算法细节的回忆
- 重点关注算法题,代码细节要熟稔于心
- PV操作部分,互斥的软硬件方式都看一下,然后基本PV分析思路了解一下
就这么简单粗暴,不用花里胡哨的
这篇关于408近年大题真题总结(后续整理入笔记)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!