408近年大题真题总结(后续整理入笔记)

2023-12-23 06:28

本文主要是介绍408近年大题真题总结(后续整理入笔记),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 题型分析
  • 算法设计题
  • 系统分析题
  • 内存+cache题
  • 虚拟内存
  • PV操作
  • 文件系统
  • IO性能
  • 计网综合
  • 复习建议

题型分析

综合18-23年的真题,一套卷从前到后基本只会考这些题型

  1. 纯算法设计(难)
  2. 算法+其他知识的综合设计,或者分析
  3. 硬件系统分析(难)
  4. 内存+cache
  5. 虚拟内存
  6. PV操作(难)
  7. 文件系统
  8. IO性能计算
  9. 计网综合

算法设计题

题型
暴力解法

如果不追求高分(135以上),算法题可以考虑暴力解法,对于计算机科班的同学来说,只要熟悉基本数据结构的操作方法,就一定可以写出来这道题,拿到7分以上的分。

建议:

  1. 一般会分为三部分
    • 首先是写算法思路。尽量分点,细节作答,比如邻接矩阵,你不要想当然认为考官知道度怎么求,你要告诉他你是用遍历一行非零元素个数的方式求度。
    • 其次是代码。和平时写代码一样,可以声明辅助函数,除了不能导库。另外注意三思而后行,辅助变量别漏了,注释写好
    • 最后可能会分析复杂度
  2. 纵观6年真题,这道题想拿分还是很容易的,不用担心颗粒无收
    • 如果想拿高分,以科班的水平,只需要将基本的那些算法代码都背一遍就好,尤其是数组,链表,二叉树的详细操作,万变不离其宗。
    • 后面第二道的算法分析题,更侧重算法广度,不要求实现,但是要求对全书的大大小小算法的特性和执行过程都有了解
    • 想拿高分,最后还是要回归到基本算法的夯实,足矣
  3. 这道题分数波动大,放在最后一个去做,如果有时间就多想,分数还可以更高,没时间就直接暴力解。

我这里简单记录一下我的思路,都是直接对着王道书标答写的:

  1. 23年
    • 很简单,遍历节点,对每个节点求入度出度,并做判断
  2. 22年
    • 考察数组储存的树的中序遍历
    • 判断一棵树是否为二叉搜索树(排序树),要用到递归的思想,直观来看就是L<N<R,但是你不能直接用最大值最小值来判断
    • 转换思路,二叉搜索树的中序遍历是有序的,从中序遍历的视角来看,就是当前节点大于前面子序列的最大值,而这个子序列就是左子树,我们只需要顺着中序遍历序列检查每一个节点是否都满足这种特性即可,不用管右边
    • 因此代码按照中序递归写法,LNR,其中,L和R都是递归,而N的判断中,只会和左子树最大值(val)比较,不用记录右子树最大值
  3. 21年
    • 这道题看着吓人,最后发现还是邻接矩阵的度计算,和23年本质一样
  4. 20年
    • 这道题牛逼,需要自己画个图,分析一下三元组距离的决定因素
    • 之后用类似于归并排序的结构写程序,每次迭代要移动的下标为数轴上最靠左的那个数的下标
    • 数据复杂度同一趟归并排序
  5. 重点:19年
    • 考察链表操作,很细腻,需要链表较强的功底,明天仔细研究一下
  6. 18年
    • 最小的正整数,要考虑已有的最长连续正整数串,其下一个数就是我们要的数。比如1234678,从1开始的连续的串是1234,因此5就是目标数
    • 已知这个串从1开始,那么其最大也就是n,因此直接用空间换时间,把符合范围的数都放到对应的位置
    • 最后从头开始扫一遍,要么断在中间,要么停在结尾,即目标数的位序

系统分析题

这类题难度比较高,是计组的精华所在

这道题拿满分不容易,拿大头是没问题的,但是他考的知识很多很杂,有的硬件知识如果你遗漏了,那就真是不会做,好在这些都是边边角角

  1. 21年真题,侧重指令结构分析
    • 1,2,考察基本指标计算
    • 3,难度所在,带符号整数减法,以及带符号整数乘法(除法),其中乘法是最难的,致命问题是符号位怎么搞?这道题取巧了,因为恰好乘8可以用算数移位做,如果让你直接算怎么办呢?
  2. 22年真题,这道题侧重CPU内部数据通路
    • 1,难点所在,现场分析标志位生成和原理,死记硬背是没用的
    • 2,3,5考察数据通路和CPU设计原理
    • 4,控制信号序列,注意写法要标准
  3. 23年真题,这道题侧重指令系统
    • 1,2考察寻址方式
    • 3考察数组元素的地址计算,注意edx×4,那个4是数据元素大小,不要当成一行的元素个数,这两个很容易混淆
    • 4考察缺页中断?
    • 关于大端和小端,一般来说都是小端,你找到一个kB长的数,看看顺序就可以验证

内存+cache题

虚拟内存

PV操作

作为科班人,我最怕的还是这道题,做不出来就颗粒无收,而当初学读者写者问题的时候,背后的逻辑一直困扰着我。

  1. 19年
    • 以哲学家问题为模板,增加了一类资源,且要有防死锁措施
    • 碗看起来是增加了限制,但是碗资源非常简单,反而不会有啥限制,能够为我所用,利用碗来限制哲学家同时进餐的上限,很妙
    • 因为碗既充当了资源,要P,也充当了防死锁机制,因此放在最外面卡着
  2. 20年
    • 经典PV思想,先V后P进行同步
    • 注意点1:信号量设法,用 S A B S_{AB} SAB这种设法最直观
    • 注意点2:因为进程太多,所以要简化进程写法,①使用CoBegin/CoEnd同时启动所有进程。②其中的每一条进程都用Begin/End包住,不区分名字,只需要用“操作A”,“操作B”来区分
  3. 21年
    • 考察PV操作的实现原理以及相关底层知识
    • 1,互斥原理,答案浅薄,就是因为多进程共享,才要互斥,并没有具体告诉你共享不互斥会出现什么情况(脏读之类),不过点到为止,小分别计较,先浅后深最好
    • 2,这个没学过,你要自己模拟一下,防止死循环
    • 3,用户无法用特权指令
  4. 22年
    • 同20年,写法略有不同,20年没有告诉你几个进程,你可以让每一个操作对应一个进程,然后用简化方法写进程
    • 22年告诉你有俩进程,并且规定了任务的归属,那就将PV穿插在每个进程的任务之间即可。同一个进程,先后顺序已经OK了,所以你只需要注意进程之间的制约即可,图可以进一步简化
  5. 23年
    • 考察了swap指令:互斥的硬件实现,大胆猜测一下,明年要么深入考一下硬件,要么就换到理发师,之类的其他没考过的PV问题了

后续怎么复习呢,硬件这块得回忆一下,其次就是经典PV问题

文件系统

IO性能

计网综合

复习建议

  1. 做过的题都翻一遍
  2. 笔记都看一遍,注重算法细节的回忆
  3. 重点关注算法题,代码细节要熟稔于心
  4. PV操作部分,互斥的软硬件方式都看一下,然后基本PV分析思路了解一下

就这么简单粗暴,不用花里胡哨的

这篇关于408近年大题真题总结(后续整理入笔记)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/527033

相关文章

Python中实现进度条的多种方法总结

《Python中实现进度条的多种方法总结》在Python编程中,进度条是一个非常有用的功能,它能让用户直观地了解任务的进度,提升用户体验,本文将介绍几种在Python中实现进度条的常用方法,并通过代码... 目录一、简单的打印方式二、使用tqdm库三、使用alive-progress库四、使用progres

python安装完成后可以进行的后续步骤和注意事项小结

《python安装完成后可以进行的后续步骤和注意事项小结》本文详细介绍了安装Python3后的后续步骤,包括验证安装、配置环境、安装包、创建和运行脚本,以及使用虚拟环境,还强调了注意事项,如系统更新、... 目录验证安装配置环境(可选)安装python包创建和运行Python脚本虚拟环境(可选)注意事项安装

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Java向kettle8.0传递参数的方式总结

《Java向kettle8.0传递参数的方式总结》介绍了如何在Kettle中传递参数到转换和作业中,包括设置全局properties、使用TransMeta和JobMeta的parameterValu... 目录1.传递参数到转换中2.传递参数到作业中总结1.传递参数到转换中1.1. 通过设置Trans的

C# Task Cancellation使用总结

《C#TaskCancellation使用总结》本文主要介绍了在使用CancellationTokenSource取消任务时的行为,以及如何使用Task的ContinueWith方法来处理任务的延... 目录C# Task Cancellation总结1、调用cancellationTokenSource.

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学