算法描述方法-牛琳整理.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
算法描述方法-牛琳整理

算法的描述方法 为了让算法清晰易懂,需要选择一种好的描述方法。算法的描述方法有很多,有自然语言、伪代码、传统流程图、N-S结构化流程图等。 1.自然语言 自然语言就是用人们日常使用的语言描述解决问题的方法和步骤,这种描述方法通俗易懂,即使是不熟悉计算机语言的人也很容易理解程序。但是,自然语言在语法和语义上往往具有多义性,并且比较烦琐,对程序流向等描述不明了、不直观。 2.伪代码 伪代码是介于自然语言和计算机语言之间的文字和符号,它与一些高级编程语言(如Visual Basic和Visual C++)类似,但是不需要真正编写程序时所要遵循的严格规则。伪代码用一种从顶到底,易于阅读的方式表示算法。在程序开发期间,伪代码经常用于“规划”一个程序,然后再转换成某种语言程序。 例如用伪代码描述商家给客户打折问题,规定一种商品一次消费金额超过200元的客户可以获得折扣(10%)。伪代码如下: sum = qyt * price if (sum 200) ??? discount = sum * 0.1 ??? rsum = sum - discount else ???rsum = sum ?3.传统流程图 传统流程图,使用不同的几何图形来表示不同性质的操作,使用流程线来表示算法的执行方向,比起前两种描述方式,其具有直观形象、逻辑清楚、易于理解等特点,但它占用篇幅较大,流程随意转向,较大的流程图不易读懂。 传统流程图的基本流程图符号及说明如表1所示。 表1流程图符号及说明 例如用传统流程图描述商家给客户打折问题,规定一种商品一次消费金额超过200元的客户可以获得折扣(10%),如图1所示。 ? 图1? 用传统流程图描述商家给客户打折的算法 4.N-S结构化流程图 N-S结构化流程图是1973年美国学者I?Nassi和B?Shneiderman提出的一种符合结构化程序设计原则的描述算法的图形方法,又叫做盒图。 N-S结构化流程图有以下几个特点: ?图中每个矩形框(除Case语句中表示条件取值的矩形框外)都是明确定义了的功能域(即一个特定控制结构的作用域),以图形表示,清晰可见。 ?它的控制转移不能任意规定,必须遵守结构化程序设计的要求。 ?很容易确定局部数据和(或)全局数据的作用域。 ?很容易表现嵌套关系,也可以表示模块的层次结构。 例如用N-S结构化流程图描述商家给客户打折问题,规定一种商品一次消费金额超过200元的客户可以获得折扣(10%),如图2所示。 ? 图2? 用N-S结构化流程图描述商家给客户打折的算法 以上介绍描述算法的方法各有特点,在实际工作中如何选择使用呢?主要参考以下几点: ① 行业惯例和软件人员使用的普遍性,易于学习掌握和交流。 ② 易于表达逻辑条件及其相应的处理,能有效地表达各种数据类型和数据结构 ③ 便于转换计算机能接受的代码,易于进行逻辑验证和便于修改。

文档评论(0)

sy78219 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档