- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第四章 算法与数据结构基础 本章学习要点: 算法 程序设计基础 数据结构基础 4.1 算法 4.1.1 解决实际问题的步骤——从问题到程序 1. 从具体问题抽象出数学模型(数学建模) 数学建模是十分关键的第一步,同时也是十分困难的一步。 数学模型一般是对实际事物的一种数学简化,建立数学模型的过程,是把错综复杂的实际问题简化、抽象为合理的数学结构的过程。 数学建模不但需要具有深厚扎实的数学基础,而且还要具有敏锐的洞察力、想象力和广博的知识面。 2.算法设计 算法的描述通常可以采用“自顶向下、逐步求精”的方法,即先建立一个抽象的、粗略的算法,然后将其逐步细化,更精确地描述出来。 算法是由一系列规则组成的过程,这些规则确定了一个操作的顺序,以便能在有限步骤内得到特定问题的解 3.程序设计 问题求解的算法确定之后必须通过程序设计(编码)将其转换为程序,才能在计算机上实现 程序设计是一个将算法转换为用程序设计语言表示的过程。根据实际情况可以采用汇编语言或高级程序设计语言来进行程序设计。 4. 调试 调试是为了发现程序中的错误而运行程序的过程。 测试前需要预先设计足够的测试数据,使用这组测试数据来测试程序是否能够获得预期的正确结果。 测试的结果如果正确,则结题结束;否则进一步测试程序是否有错。如果程序有错,则转去修改程序;否则需要检查算法是否有错。如果算法有错,则转去修改算法;否则将需要重新进行数学建模,检查问题的数学模型与实际要求是否相符。 4.1.2 什么是算法 1. 算法的定义 算法(Algorithm)是对特定问题求解步骤的一种描述,是指令的有限序列 2.算法的特性 (1)有穷性(Finiteness) 一个算法必须在有穷步之后结束,即必须在有限时间内完成。实际应用中,算法的有穷性应该包括执行时间的合理性。 (2)确定性(Definiteness) 算法的每一步必须有确切的含义,无二义性,且在任何条件下算法只有唯一一条执行路径,即对于相同的输入只能得出相同的输出。 (3)可行性(Effectiveness) 算法中的每一步都可以通过已经实现的基本运算的有限次执行得以实现。 (4)输入(Input) 一个算法具有零个或多个输入,这些输入取自特定的数据对象集合。 (5)输出(Output) 一个算法具有一个或多个输出,这些输出同输入之间存在某种特定的关系。 3.算法和程序的区别 一个算法必须是有穷的,但一个程序不一定满足有穷性 程序中的指令必须是机器可执行的,而算法中的指令则无此限制 算法代表了对问题的解,而程序则是算法在计算机上特定的实现 4.算法的描述 (1)自然语言描述 自然语言就是用人们日常使用的语言描述解决问题的方法和步骤,描述方法通俗易懂 自然语言在语法和语义上往往具有多义性,并且比较烦琐,对程序流向等描述不明了、不直观 (2)伪代码描述 伪代码是介于自然语言和计算机语言之间的文字和符号,它与一些高级编程语言(如C和 C++)类似,但是不需要真正编写程序时所要遵循的严格规则。 伪代码用一种从顶到底,易于阅读的方式表示算法。在程序开发期间,伪代码经常用于“规划”一个程序,然后再转换成某种语言程序。 3.流程图描述 流程图使用不同的几何图形来表示不同性质的操作,使用流程线来表示算法的执行方向, 流程图具有直观形象、逻辑清楚、易于理解等特点,但它占用篇幅较大,流程随意转向,规模较大的流程图不易读懂。 图 4-1 流程图基本符号及其含义 4.1.3 算法的评价标准 1.正确性 算法的执行结果应当满足预先规定的功能和性能的要求。正确性表明算法必须满足实际需求,达到解决实际问题的目的。 2.可读性 一个算法应当思路清晰、层次分明、简单明了、易读易懂。可读性要求表明算法主要是人与人之间交流解题思路和进行软件设计的工具,因此可读性必须强。同时一个可读性强的算法,其程序的可维护性、可扩展性都要好许多, 返回本节首页 返回本章首页 3.健壮性 健壮性要求表明算法要全面细致地考虑所有可能出现的边界情况,并对这些边界条件做出完备的处理,尽可能使算法没有意外的情况。 4.高效性 有效使用存储空间和有较好的时间效率。高效性要求主要是指时间效率,即解决相同规模的问题时间尽可能短。 4.2 程序设计基础 4.2.1 程序设计语言 程序设计语言是人与计算机交互的工具,人要把需要计算机完成的工作告诉计算机,就需要使用程序设计语言编写程序,让计算机去执行。 随着计算机科学技术的发展,程序设计语言也经历了机器语言、汇编语言和高级程序设计语言3个阶段。 4.2.2 结构化程序设计 1. 什么是结构化程序设计 结
您可能关注的文档
- 规范汉字与书法艺术第二单元千姿百态展魅力源远流长传文明.ppt
- 规范汉字与书法艺术第九单元铁笔有力传神韵我以我手写我心.ppt
- 规范汉字与书法艺术第六单元一气呵成凭运腕笔通造化焕精神.ppt
- 规范汉字与书法艺术第七单元体态端庄杂流丽点画刚健含婀娜.ppt
- 规范汉字与书法艺术第三单元玉露磨来雅兴起银笺染处豪情生.ppt
- 规范汉字与书法艺术第十单元字妙盈虚相映带行巧起伏气贯通.ppt
- 规范汉字与书法艺术第十一单元法度之中出新意逸群翰墨藏匠心.ppt
- 规范汉字与书法艺术第四单元未闻执笔之真传钟王学尽徒茫然.ppt
- 规范汉字与书法艺术第五单元古纸硬黄临晋帖新笺匀碧录唐诗.ppt
- 规范汉字与书法艺术第一单元笔如龙蛇堪称妙字守规范更有神.ppt
文档评论(0)