C/C++程序设计教程
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人

1.4.2 算法描述

算法的描述就是用文字或图形把算法表示出来。常用的描述方法有:自然语言、流程图、N-S流程图、伪代码等。

1.自然语言

自然语言就是人们日常使用的语言,可以是汉语、英语或其他语言。用自然语言描述算法通俗易懂,但也存在如下缺点:

① 往往要用一段较冗长的文字才能表达清楚要进行的操作;

② 容易出现“歧义性”,往往要根据上下文才能正确判断出它的含义,不太严谨;

③ 如果用自然语言描述的算法是顺序执行的,还比较容易理解,当算法中包含了判断和转移等步骤时,用自然语言描述就不容易理解。

【例1.1】 求任意3个正整数a, b, c中的最大者。

用自然语言描述的算法如下:

① 输入a, b, c;

② a和b比较,若a>b则a=>max,否则b=>max;

③ c和max比较,若c>max,则c=>max;

④ 输出max。

2.传统流程图

传统流程图是用一些几何图形框、线条和文字来描述各种操作,是使用最早的算法和程序描述工具。美国国家标准化协会规定了一些常用流程图符号,如图1.1所示。

图1.1 常用传统流程图符号

用传统流程图描述的例1.1如图1.2所示。

图1.2 例1.1的传统流程图

3.N-S流程图

N-S流程图简称N-S图。这种流程图能清楚地显示出程序的结构。但当嵌套层数太多时,内层的方框将越画越小,从而影响图形的清晰度。

N-S 结构流程图用以下三种基本元素框来表示三种基本结构。

(1)顺序结构

图1.3表示的是顺序结构,即依次执行A、B语句或语句组。

图1.3 顺序结构

(2)选择结构

图 1.4 表示的是选择结构,其意义是:当条件p成立时执行A操作,条件p不成立时执行B操作。

图1.4 选择结构

(3)循环结构

图1.5(a)是当型循环结构,它表示的意义是:当条件p1成立时反复执行A操作,直到条件p1不成立时为止。图1.5(b)是直到型循环结构,它表示的意义是:反复执行A操作,直到条件p2不成立时为止。

图1.5 N-S结构流程图

由于 N-S 图废除了流程线,因此比传统流程图更紧凑、易画,整个算法结构是由各个基本结构按顺序组成的,其上下顺序就是执行顺序,使写算法和看算法只需从上到下进行,十分方便。但由于 N-S 图仅使用三种基本结构设计程序,因此使某些程序设计的实现变得繁琐和困难。

图1.6是描述例1.1的N-S图。

图1.6 例1.1的N-S图

4.伪代码

伪代码(Pseudo-code)又称程序设计语言 PDL,是用介于自然语言和计算机语言之间的文字和符号来描述算法的。根据编程语言的不同,有对应的类xxx语言,例如类C、类Pascal等。伪代码借助于某些高级语言的控制结构和一些自然语言的嵌套,每一行(或几行)表示一个基本操作,书写方便,格式紧凑,比较好懂,很容易转化为高级语言程序。

伪代码可以用英文、汉字、中英文混合表示算法,以便于书写和阅读为原则。用伪代码描述算法并无固定的、严格的语法规则,它比程序设计语言更容易描述和理解,又比自然语言更接近程序设计语言,只要把意思表达清楚,书写格式清晰易读即可。

下面是描述例1.1的伪代码。

read  a,b,c
if a>b
  a=>max
else
  b=>max
if c>max
  c=>max
print max

用自然语言、流程图、N-S流程图、伪代码描述的算法很容易转换为计算机程序,只要选择一种计算机语言,按照其语法规则,就可以编写出计算机程序。