软考选择题知识点总结

这篇博客汇总了软件设计师考试中的关键知识点,涵盖了编译原理、数据结构、网络、操作系统、数据库、网络安全等多个方面。从词法分析到堆排序,从哈希表到Dijkstra算法,再到数据库的事务管理和分布式数据库,全面解析了软件开发和设计的核心概念。此外,还涉及了网络安全的加密模型和风险管理,以及项目管理和软件工程的敏捷开发和UML建模。
摘要由CSDN通过智能技术生成

阅读注意

文章大概1万字左右 涵盖大部分软件设计师选择题知识点 易错点 详细内容看书或者搜索 望周知

软考

上半年报名3月14 ~ 3月20日 考试时间 5.27

下半年报名8月26日 ~ 9月2日 考试时间11.5

希赛网题库网址

https://wangxiao.xisaiwang.com/tiku2/list-stk136-1.html

编译原理

语法规则:上下文无关文法

在C程序中

代码区存放二进制代码

堆区heap放全局变量和静态变量

栈区由编译器自动分配释放 存放函数的参数值及局部变量

程序中常量的值在运行时不能改变

解释和编译

编译程序生成 可执行文件 直接运行 无法进行控制

而解释程序可以逐条解释执行 用于调试模式 可以控制源程序 执行速度慢 效率低

在词法、语法、语义分析方面 编译方式和解释方式没有区别

源程序—>目标代码

1词法分析 从左到右一个一个字符依次读入源程序 即对构成源程序的字符流进行扫描然后识别单词 记号流 <正规式 有限自动机>

2语法分析 将单词序列组合成各类语法短语并判断结构上是否正确<单词是否拼写正确> 生成语法树

3语义分析 对源程序进行上下文类型审查 <识别静态错误>

4中间代码生成 后缀式(二叉树后缀遍历) 三地址码 不依赖于平台 可移植性强

5目标代码 之后完成分配寄存器工作

动态错误/0 数组越界 会抛出异常的错误!

编译预处理会生成符号表

正则式

*表示匹配前面的子表达式<括号内元素或者紧邻的元素>任意次

反编译

一般不能将可执行文件还原成高级语言源代码 只能转换为等价的汇编程序

语法分析

自上而下:递归下降分析法 预测分析法

自下而上:移进-归约法

数据结构

区分比较次数和时间复杂度和渐进时间复杂度
渐进时间复杂度是当问题规模趋向于无穷大时该算法的数量级

迭代方式比递归时空效率更高

广义表 递归形式 head<取头> tail<取尾> 深度==括号层数

顺序存储和链式存储

1)有且只有一个根节点

2)每个node 至多有一个前件 也至多有一个后件

线性表

存储方式:顺序存储和链式存储(不一定连续存储)
队列、栈均为线性表线性结构

序列有子序列 2 n 个,并且暴力求解最长公共子序列时间复杂度是 2 n ∗ n 序列有子序列2^n个,并且暴力求解最长公共子序列时间复杂度是2^n*n 序列有子序列2n个,并且暴力求解最长公共子序列时间复杂度是2nn

队列

优先队列 堆实现

树非线性结构
n0=n2+1 //可用分支 上下 进行推理

最优二叉树 <哈夫曼树 无损压缩 可还原 带权路径长度 平均带权路径长度>

查找二叉树<leftmin,thismid,rightmax> <无相等元素>

平衡二叉树<left right <=1>

完全二叉树 <适合采用数组存储>

完全图更适合邻接矩阵存储

顶点数决定了邻接矩阵的阶和临界表中的单链表数目

无论是有向图还是无向图边数的多少决定了单链表中的节点数

拓扑序列<即AOV网络> 入度为0

图的遍历 DFS<树前序遍历>、BFS<树的层序遍历>

最短路径

Dijkstra算法<贪心>

最小生成树

<构建无环路>

贪心算法<递归技术联系最弱>
Prim 网稠密更适合 O(n*n)
Kruscal 选边

查找

散列表 线性探测解决关键字冲突问题 取余数求hash值

二分查找

只适用顺序存储的有序表
有序线性表中进行二分查找 最坏O(log2n)
mid值向下取整! 并且区间值变化为相应的一边 比较位置不用再次考虑!

顺序查找 最大值最小值的比较次数为n-1次

动态查找:若在查找过程中同时插入查找表中不存在的元素 或者从查找表中删除已存在的某个元素

二叉排序树是动态查找表

排序

选择冒泡插入希尔快速归并堆排序

堆排序

n*log2n

用插入和归并排序对数组<3,1,4,1,5,9,6,5>进行非递减排序 则分别需要进行多少次排序

基本有序适合插入排序 最好时间复杂度是O(n)

两个递增序列A、B归并时 第一个元素开始 分别从这两个序列中取出一个元素进行比较,将较小者输出,然后从较小者所在序列取下一个元素进行比较,循环往复,直到某个序列的全部元素完全输出,再将另一个序列的剩余元素依次输出即可!
a 1 < a 2 < . . . . a m < b 1 < b

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

「已注销」

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值