- 1、本文档共139页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ch2计算机辅助工程基本
第二章 计算机辅助工程基础 数据结构 例—交叉口仿真系统控制结构 当采用仿真方法分析一系列交叉口所发生的交通状态时,需要采用分时处理技术分别逐个改变每一个交叉口的状态,同时系统整体环境也在发生着一些具有时间先后次序的情况。 二叉树 二叉树在树结构的应用中起着非常重要的作用 对二叉树的许多操作算法简单; 而任何树都可以与二叉树相互转换,解决了树的存储结构及其运算中存在的复杂性。 定义:二叉树是由n(n=0)个结点的有限集合构成,此集合或者为空集,或者由一个根结点及两棵互不相交的左右子树组成,并且左右子树都是二叉树。 这也是一个递归定义。二叉树可以是空集合,根可以有空的左子树或空的右子树。 二叉树结点的子树要区分左子树和右子树,即使只有一棵子树也要进行区分,说明它是左子树,还是右子树。这是二叉树与树的最主要的差别。 二叉树的5种形式 例题 已知一棵二叉树的前序遍历的结果是ABECDFGHIJ, 中序遍历的结果是EBCDAFHIGJ, 试画出这棵二叉树。 当前序序列为ABECDFGHIJ,中序序列为EBCDAFHIGJ时,逐步形成二叉树的过程如下图所示: 习题 给定权值集合{15, 03, 14, 02, 06, 09, 16, 17}, 构造相应的霍夫曼树, 并计算它的带权外部路径长度。 假定用于通信的电文仅由8个字母c1, c2, c3, c4, c5, c6, c7, c8组成, 各字母在电文中出现的频率分别为5, 25, 3, 6, 10, 11, 36, 4。试为这8个字母设计不等长Huffman编码, 并给出该电文的总码数。 解答 已知字母集 { c1, c2, c3, c4, c5, c6, c7, c8 },频率 {5, 25, 3, 6, 10, 11, 36, 4 },则Huffman编码为: 最短路径 求最短路径的Dijkstra算法 设有向图G=(V,E),其中,V={0,1,2,……,n},cost是表示G的邻接矩阵,cost[i][j]表示有向边i,j的权。若不存在有向边i,j,则cost[i][j]的权为无穷大。 设s是一个集合,其中的每个元素表示一个顶点,从源点到这些顶点的最短距离已经求出。设顶点1为源点,集合初态s={0}。 数组dist记录从源点到其他各项点当前的最短距离,其初值为dist[i]=cost[0][i],i=1,2,…,n。 从s之外的顶点集合V-S中选出一个顶点w,使dist[w]的值最小。于是从源点到达w只通过s中的顶点,把w加入集合s中,调整dist中从源点到V-S中每个顶点v的距离: dist[v] =min{dist[v],dist(w)+cost[w][v]} 最短路径 重复上述过程,直到s中包含v中其余各项点的最短路径。 最终结果是:s记录了存在从源点到达的路径的顶点集合,数组dist记录了从源点到V中到其余各项点之间的最短路径. Example Answer Answer (Con 1) 最后的输出结果如下: 1←3←2 35 2 0 3←2 15 4←3←2 30 5←2 10 6←2 ∞ 算法及其复杂度分析 (1)有穷性:一个算法必须总是(对任何合法的输入值)在执行有穷步之后结束,且每一步都可在有穷时间内完成。 (2)确定性:算法中每一条指令必须有确切的含义,读者理解时不会产生二义性。并且在任何条件下,算法只有唯一的一条执行路径,即对于相同的输入只能得出相同的输出。 (3)可行性:一个算法是可行的,即算法中描述的操作都是可以通过已经实现的基本运算执行有限次来实现的。 (4)输入:一个算法有零个或多个的输入,这些输入取自于某个特定的对象的集合。 (5)输出:一个算法有一个或多个的输出。这些输出是同输入有着某些特定关系的量。 算法及其复杂度分析 通常设计一个“好”的算法应考虑达到以下目标: (1)正确性:算法应当满足具体问题的需求。通常一个大型问题的需求,要以特定的规格说明方式给出,而一个不那么严格的问题至少应当包括对于输入、输出和加工处理等明确的无歧义性的描述。设计或选择的算法应当能正确地反映这种需求。 (2)可读性:算法主要是为了人的阅读与交流,其次才是机器执行。可读性好有助于人对算法的理解;晦涩难懂的程序易于隐藏较多错误,难以调试和修改。 (3)健壮性:当输入数据非法时,算法也能适当地作出反应或进行处理,而不会产生莫明其妙的输出结果。 (4)效率与低存储量需求:通俗地说,效率指的是算法执行时间。存储量需求指算法执行过程中所需要的最大存储空间。一个好算法要有高的执行效率和低的存储量需求。 算法及其复杂度分析 通常设计一个“好”的算法应考虑达到以下目标: (1)正确性:算法应当满足具体问题的需求
您可能关注的文档
- 9-西欧与日本的经济进展.ppt
- 9-邱关源电路第9章节[已改].ppt
- 96中7-1班期中考试后家长会.ppt
- 9—工程质量数码照片的管理与深化应用.ppt
- 9—2用对立统一的观点看问题.ppt
- 9—数字集成电路基本单元与版图.ppt
- 9—6—1—0人民当家做主的法治国家.ppt
- 9古诗两首ppt演示课件1.ppt
- 9古诗两首“夜书所见”“九月九日忆山东兄弟”.ppt
- 9泉城ppt演示课件—张本洲.ppt
- Unit 3 My day Lesson 3(课件)冀教版(三起)(2024)英语三年级下册.pptx
- Unit 4 Have fun after class (story)课件-三年级英语下学期(译林版三起2024).pptx
- Unit 2 Clean our classroom(Lead in&Cartoon)(课件)三年级英语下学期(译林版三起2024).pptx
- Unit 3 Learning better PartA let's learn(课件)人教PEP版(2024)英语三年级下册.pptx
- 第一单元“精神 信仰 力量 情感”——第一节《十送红军》《情深意长》课件 湘艺版(2024)七年级音乐下册.pptx
- Unit 3 Learning better Part A Let's learn(课件)人教PEP版(2024)英语三年级下册.pptx
- 5.6回收废品(课件)一年级数学下册数学 北师大版2024.pptx
- Unit2 Expressing yourself PartA(课件)人教PEP版(2024)英语三年级下册.pptx
- 13 要下雨了 课件-语文一年级下册统编版.pptx
- Unit 1 School things ((Story time)(课件)译林版(三起)(2024)英语三年级下册.pptx
文档评论(0)