- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C语言算法和数据结构
第十二章算法与数据结构 12.1 算法的基本概念 该节知识点所占试题比重为12%,属于重点考查对象,基本上每次必考,主要考查算法的定义和对算法复杂度的理解。历次试题分值在0-4分之间波动。 12.1.1 考点1: 算法的定义 算法是对一个问题求解步骤的一种描述,是求解问题的方法,它是指令的有限序列,其中每条指令表示一个或者多个操作。一般来说,一个算法具有以下5个主要特性。 有穷性:一个算法(对任何合法的输入)在执行有穷步后能够结束,并且在有限的时间内完成。 确定性:算法中的每一步都有确切的含义。 可行性:算法中的操作能够用已经实现的基本运算执行有限次来实现。 输入:一个算法有零个或者多个输入,零个输入就是算法本身确定了初始条件。 输出:一个算法有一个或者多个输出,以反映出数据加工的结果。 12.1.2 考点2:算法复杂度 算法复杂度包括时间复杂度和空间复杂度,是衡量一个算法好坏的度量。 1、时间复杂度:基本操作重复执行的次数的阶数 T(n)=o(f(n)) 2、空间复杂度:是算法所需空间的度量。 G(n)= O(f(n)) 12.2 数据结构的定义 该节知识点所占试题比重为12%,属于重点考查对象,基本上每次必考,主要考查数据的逻辑结构和存储结构。历次试题分值在0-4分之间波动。 12.2.1考点1:什么是数据结构 一、基本概念和术语 数据(data)—所有能输入到计算机中去的描述客观事物的符号 数据元素(data element)—数据的基本单位,也称节点(node)或记录(record) 数据项(data item)—有独立含义的数据最小单位,也称域(field) 数据结构(data structure)—数据元素和数据元素关系的集合 12.2.2考点2:数据结构的图形表示 根据数据元素之间关系的不同,通常有4种结构:集合、线性结构、树型结构和图状结构。 12.3线性表 线性表一般和其他知识点结合起来出题。在每次所考的数据结构、栈、队列、链表、查找、排序等试题中,均涉及线性表的概念。 12.3.1考点1:线性表 一、线性结构特点:在数据元素的非空有限集中 存在唯一的一个被称作“第一个”的数据元素 存在唯一的一个被称作“最后一个”的数据元素 除第一个外,集合中的每个数据元素均只有一个前驱 除最后一个外,集合中的每个数据元素均只有一个后继 二、线性表的逻辑结构 定义:一个线性表是n个数据元素的有限序列 12.3.2考点2:线性表的顺序存储结构 它用一组地址连续的存储单元来存储线性表的元素。 线性表中第i+1个元素的存储位置loc(ai+1)和第i个元素的存储位置loc(ai)满足以下关系: Loc(ai+1)=loc(ai)+S其中: S—一个元素占用的存储单元个数 LOC(ai)—线性表第i个元素的地址 特点: 实现逻辑上相邻—物理地址相邻 实现随机存取 实现:可用C语言的一维数组实现 12.3.2考点2:线性表的顺序存储结构 线性表的第i个元素的存储位置为: Loc(ai)=loc(a1)+(i-1)×s 其中,loc(a1)表示第1个数据元素的存储位置,一般被称为线性表的基地址。 12.3.3考点3:线性表的插入和删除操作 线性表的插入操作是指在线性表的第i个元素与第i+1个元素之间插入一个新的数据元素a,使长度为n的线性表 (a1…,ai,ai+1,…,an) 变成长度为n+1的线性表 (a1…,ai,a,ai+1,…,an) 算法时间复杂度T(n) 在长度为n的线性表中插入一个元素时,所需移动的元素的平均次数为:n/2 12.3.3考点3:线性表的插入和删除操作 删除操作是在线性表中删除一个元素ai,使长度为n的线性表 (a1…,ai,ai+1,…,an) 变成长度为n-1的线性表 (a1…,ai-1,ai+1,…,an) 算法时间复杂度T(n) 在长度为n的线性表中删除一个元素所需移动的元素的平均次数为(n-1)/2 12.4栈 该节知识点所占试题比重为12%,属于重点考查对象,基本上每次必考,主要考查栈的定义、存储结构及基本运算。历次试题分值在0-2分之间波动。 12.4.1 考点1:什么是栈 栈是限定仅在表尾进行插入和删除操作的线性表。 允许插入和删除的一端叫做栈顶,另一端叫做栈底。 不含有元素的栈叫做空栈。 12.4.2 考点2:栈的顺序存储结构 栈的顺序存储结构是利用一组连续地址的存储单元来存储从栈底到栈顶的数据元素,同时附设一个指针top指示栈顶元素在顺序栈中的位置,一个指针base指示栈底元素的位置。 12.4.3 考点3:栈的插入和删除运算 栈的插入和删除运算只能在栈顶进行。 12.5队列
您可能关注的文档
- Charles:产品中试管理-从样品到量产.ppt
- CLS材料作文审题立意.ppt
- Chapter1_第一节_2010.ppt
- chp2_财务分析信息基础.ppt
- Chapter3.1_3.2线性规划的对偶和灵敏度分析.ppt
- chapter9静电场中的导体及电介质2011formath.ppt
- class02变量、常量及数据类型.ppt
- CO2气体保护焊的原理和特点.ppt
- CMOS逻辑电路和时序电路分析.ppt
- COITKDJRSI走势技巧.pptx
- 基于人工智能教育平台的移动应用开发,探讨跨平台兼容性影响因素及优化策略教学研究课题报告.docx
- 高中生物实验:城市热岛效应对城市生态系统服务功能的影响机制教学研究课题报告.docx
- 信息技术行业信息安全法律法规研究及政策建议教学研究课题报告.docx
- 人工智能视角下区域教育评价改革:利益相关者互动与政策支持研究教学研究课题报告.docx
- 6 《垃圾填埋场渗滤液处理与土地资源化利用研究》教学研究课题报告.docx
- 小学音乐与美术教师跨学科协作模式构建:人工智能技术助力教学创新教学研究课题报告.docx
- 《航空航天3D打印技术对航空器装配工艺的创新与效率提升》教学研究课题报告.docx
- 教育扶贫精准化策略研究:人工智能技术在区域教育中的应用与创新教学研究课题报告.docx
- 《区块链技术在电子政务电子档案管理中的数据完整性保障与优化》教学研究课题报告.docx
- 《中医护理情志疗法对癌症患者心理状态和生活质量提升的长期追踪研究》教学研究课题报告.docx
文档评论(0)