- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[二级公共基础知识考点总结
二级公共基础知识考点总结
数据结构与算法
考点1:算法的概念和基本特征
算法是指解题方案的准确而完整的描述。
算法的基本特征包括:
(1)可行性:针对实际问题设计的算法,总是在某个特定计算工具上执行,往往要受到计算工具的限制,使执行结果产生偏差。(2)确定性:算法中每一步骤都必须有明确定义,不充许有模棱两可的解释,不允许有多义性。(3)有穷性:算法必须能在有限的时间内做完,即能在执行有限个步骤后终止,包括合理的执行时间的含义。(4)拥有足够的情报:拥有足够的输入。
考点5:栈与队列(属于线性结构)
1、栈
栈是限定在一端进行插入与删除的线性表。
在栈中,允许插入与删除的一端称为栈顶,不允许插入与删除的另一端称为栈底。通常用指针top指示栈顶的位置,用指针bottom指向栈底。
top-bottom的绝对值加1即为当前栈中元素的个数。
栈是按照“先进后出”或“后进先出”的原则组织数据的,用栈顶指针top动态反映了栈中元素的变化情况,而不须改变指针bottom的位置。
栈具有记忆作用。
2、队列
队列是指允许在一端进行插入、而在另一端进行删除的线性表。允许插入的一端称为队尾,通常用一个尾指针rear指向队尾元素,允许删除的一端称为排头(也称队头),通常用一个排头指针front指向排头元素的前一个位置。
队列按照“先进先出”或“后进后出”的原则组织数据,队尾指针rear和排头指针front共同反映了队列中元素动态变化情况。
在实际应用中,队列的顺序存储结构一般采用循环队列的形式,循环队列是逻辑上的环状空间,但物理上仍然是线性结构。从排头指针front指向的后一个位置直到队尾指针rear指向的位置之间所有的元素均为队列中的元素。
在普通队列中,rear指针位置减去front指针位置的差值即为队列中元素的个数。但在循环队列中,rear指针的位置可能大于front指针的位置,也可能小于front指针的位置,所以循环队列的元素个数计算方法如下:
设循环队列总容量为m
如果rearfront,则循环队列的元素个数为rear-front
如果rearfront,则循环队列的元素个数为m+(rear-front)
栈与队列的共同点:皆为线性结构,只允许在端点处插入与删除,而且不须移动其他元素。
考点6:线性链表
线性表的链式存储结构称为线性链表
在链式存储结构中,存储数据结构的存储空间可以不连续,各数据结点的存储顺序与数据元素之间的逻辑关系可以不一致。
链式存储结构即可用于表示线性结构,也可用于表示非线性结构,栈与队列也可以采用链式存储结构。
考点7:二叉树的基本性质
树是典型的非线性结构,在树中,每个结点的前件称为父结点,没有父结点的只有一个,称为根结点(有且仅有一个)。
每个结点拥有的后件称为子结点,没有子结点的称为叶子结点。一个结点所拥有的子结点的个数称为该结点的度,叶子结点的度为0。
树的最大层次称为树的深度。
二叉树:每个结点最大的度为2,如下图所示
性质1:在二叉树的第k层上,最多有2k-1个结点
性质2:深度为m的二叉树最多有2m-1个结点
性质3:在任意一棵二叉树中,度为0的结点(叶子结点)总是比度为2的结点多一个。
满二叉树:每一层上的结点数都达到最大值,即第k层上有2k-1个结点,且深度为m的满二叉树有2m-1个结点
完全二叉树:除最后一层外,每一层上的结点数均达到最大值;在最后一层上只缺少右边的若干结点。当完全二叉树有n个结点,若n为偶数,则有n/2个叶子结点;若n为奇数,则有[n/2]+1个叶子结点([ ]表示只取整数部分)。
★考点8:二叉树的遍历
(1)前序遍历(DLR),首先访问根结点,然后遍历左子树,最后遍历右子树;(2)中序遍历(LDR),首先遍历左子树,然后访问根结点,最后遍历右子树;(3)后序遍历(LRD)首先遍历左子树,然后访问遍历右子树,最后访问根结点。
软件的特点包括:(1)软件是一种逻辑实体,而不是物理实体。(2)软件的生产与硬件不同,它没有明显的制作过程;(3)软件在运行、使用期间不存在磨损、老化问题;(4)软件的开发、运行对计算机系统具有依赖性,受计算机系统的限制,这导致了软件移植的问题;(5)软件复杂性高,成本昂贵;(6)软件开发涉及诸多的社会因素。
软件按功能可以分为:应用软件、系统软件和支撑软件〔或工具软件。
软件工程包括3个要素:方法、工具和过程。方法是完成软件工程项目的技术手段;工具支持软件开发、管理、文档生成;过程支持软件开发的各个环节的控制、管理
考点3:软件生命周期
定义阶段:可行性研究、需求分析
开发阶段:概要设计、详细设计、实现、测试
维护阶段:使用、维护、退役
考点4:结构化分析方法
1、结构化分析的
文档评论(0)