阅读注意
文章大概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个,并且暴力求解最长公共子序列时间复杂度是2n∗n
队列
优先队列 堆实现
树
树非线性结构
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