- 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章算法及其设计基础
流程图方式、盒图(N-S图)、PAD图方式。教学目的和要求重点:了解算法描述的基本要求和目的,掌握用自然语言方式、流程图方式、盒图(N-S图)、伪代码方式、PAD图方式和计算机语言方式来描述一个算法。完整地用盒图(N-S图)来描述一个算法。难点:
程序设计方法首先强调的是设计,其次才是实现(写出程序代码)。其核心是将程序设计过程分为两部分。01第一部分集中于问题及其解法或算法,与任何特定的计算机或计算机语言无关。02第二部分集中于选择某一种程序设计语言,把算法表达给特定的计算机。031.1引言
广义地说,为解决一个问题而采取的方法和步骤,就称为“算法”。?你想查看计算机CPU,首先必须将计算机断电,拆除连线,打开机箱,然后按下夹子解除夹口,最后取出CPU进行查看。?复制文件,首先要寻找所要复制的文件,然后选中,再进行复制,最后移动到需要的地方进行粘贴。1.2算法的概念
计算机算法的分类:本书所讲述的算法只限于计算机算法,即计算机能执行的算法。在设计一个计算机算法时,应当考虑到计算机能否执行。计算机算法可分为两大类别:数值运算算法和非数值运算算法。数值运算的目的是求数值解,例如求方程的根,求一个函数的定积分等,都属于数值运算范围。非数值运算包括的面十分广泛,最常见的是用于事务管理领域,例如图书检索、人事管理等。目前,计算机在非数值运算方面的应用远远超过了在数值运算方面的应用。
有穷性确定性输入输出01有效性02一个算法应该具有以下几个特性:1.3算法的特性
一个算法应包含有限的操作步骤,而不能是无限的。01但是要注意,“有穷性”往往指“在合理的范围之内”。如果让计算机执行一个历时几百年才结束的算法,这虽然是有穷的,但超过了合理的限度,人们也不把它视做有效算法。究竟什么算“合理限度”,并无严格标准,由人们的常识和需要而定。02有穷性1.3算法的特性
例如,某人只说请您“复制文件”或查看计算机的CPU,是不确定的,因为此人没有说明复制哪一个文件或查看哪一台计算机的CPU。算法中的每一个步骤,必须是确切定义的,而不应当含糊不清或模棱两可的。即算法的含义应当是唯一的,而不应当产生“歧义性”。确定性1.3算法的特性
21输入例如,让计算机来完成“将N个正数按从小到大的次序排列”时,就需要输入N个正整数。一个算法可以有多个输入,也可以没有输入。所谓输入是指在执行算法时需要从外界取得必要的信息。31.3算法的特性
输出A算法执行过程中往往会产生一些数据,它们在算法执行之后被保存下来或传递给算法的调用者,这些数据被称为算法的输出。B一个算法可以有多个输出,没有输出的算法是没有意义的。C例如,计算机来完成“将N个整数按从小到大的次序排列”的算法时,输出的整数将是一组“从小到大的次序排列的N个整数”。D1.3算法的特性
01有效性02一个算法应该是具有现实意义的,如果算法中含有不能实现的某一个步骤,则这个所谓的“算法”无法解决问题,因此,不能称为算法。03算法贯穿于程序设计的始终,希望读者对算法给予很大的重视,在解决一个问题之前应当首先构造出一个好的算法。在本书各章中都贯穿这一原则。1.3算法的特性
1966年,计算机科学家Bohm和Jacopini的研究表明,任何简单或复杂的算法都可以由下述3种基本控制结构组成。01顺序结构02选择结构03循环结构041.4算法的结构
1)顺序结构这是最简单的一种基本结构。顺序结构中的各个部分是按书写顺序依次执行的。例如某个算法中可能出现下列形式的一组操作: ……操作1操作2操作3……如果这样一组操作的执行顺序与操作出现的前后顺序相同,即先进行“操作1”,然后进行“操作2”,再后进行“操作3”,那么这段算法的结构就是顺序结构。
这种结构也称为分支结构,它表示操作的处理步骤出现了分支,它需要根据某一特定的条件选择其中的一个分支执行。例如下述算法描述片段:1如果条件成立 则执行操作1 否则执行操作22操作1和操作2之间构成了一种选择关系,两个操作中哪一个将被执行是通过对条件的判断来控制的。32)选择结构
循环结构是指被重复执行的一个操作集合。例如下述算法描述片段:重复执行操作直到条件不成立这段描述指出操作将被反复运行多次,直到条件不成立为止。0102033)循环结构
注意:通过上述三种基本控制结构可以看到,它们有一个共同的特点,即:只有一个入口且只有一个出口,并且操作不会出现死循环。
算法的描述具有重要意义,描述一个算法的目的在于使其他人能够利用算法解决具体问题。01算法的描述方式没有统一规定,本书将介绍常用的自然语言、流
您可能关注的文档
最近下载
- 2025年高考历史试卷(山东卷)附答案解析.docx VIP
- 中国文化古城—西安.-PPT.pptx VIP
- 《西方社会学理论》全套教学课件.ppt
- 第7课 实践出真知 课件 中职高教版哲学与人生.pptx
- 一针疗法之肩周炎.ppt
- 2025中国银行中银国际证券股份有限公司招聘8人笔试模拟试题及答案解析.docx VIP
- 神经介入治疗概述及护理常规.ppt VIP
- 舒伯特第二即兴曲,降E大调 D.899之2 Impromptu No. 2 in E flat major, D. 899, No. 2 Op90 Schubert钢琴谱.pdf VIP
- 深潜器钛合金框架结构装配焊接工艺研究-中国造船工程学会.doc
- 村两委工作细则汇编.doc VIP
文档评论(0)