C的四种程序结构!

如何学习C 语言的四种程序结构

1)顺序结构

2)分支结构

3)循环结构

4) 模块化程序结构

(1)顺序结构

这种结构的程序比较简单,就是按照语句的排列顺序依次执行的机制。顺序结构的执行顺序是自上而下,依次执行,因此编写程序也必须遵守这一规定,否则你的程序执行结果就不对。

例如;a = 3,b = 5,现交换a ,b 的值,正确的程序为:

c = a; a = b; b = c;

执行结果是a = 5,b = c = 3如果改变其顺序,写成:

a = b; c = a; b = c;

则执行结果就变成a = b = c = 5,不能达到预期的目的,这是初学者常犯的错误。

顺序结构可以独立使用构成一个简单的完整程序,常见的输入、计算,输出三步曲的程序就是顺序结构,例如计算圆的面积,其程序的语句顺序就是输入圆的半径R ,计算S = 3.14159*R*R,输出圆的面积S 。而大多数情况下顺序结构都是作为程序的一部分,与其它结构一起构成一个复杂的程序,例如分支结构中的块体、循环结构中的循环体等。

(2) 分支结构

分支结构与顺序结构不同,其执行是依据一定的条件选择执行路径,而不是严格按照语句出现的物理顺序。分支结构的程序设计方法的关键在于构造合适的分支条件和分析程序流程,根据不同的程序流程选择适当的分支语句。

分支结构适合于带有逻辑条件判断的计算,设计这类程序时往往都要先绘制其程序流程图,然后根据程序流程写出源程序,这样做把程序设计分析与语言分开,使得问题简单化,易于理解。程序流程图是根据解题分析所绘制的程序执行流程图。

学习分支结构不要被分支嵌套所迷惑,只要弄清基本的分支结构,嵌套结构也就不难了。嵌套只不过是分支块体中又包括分支语句而已,不是新知识,只要你基础知识扎实,分支嵌套也难不住你,下面我们重点讨论几种基本的分支结构的学习方法。

①If(条件)

{

}

这种分支结构中的块可以是一条语句,此时“{ }”可以省略,也可以是多条语句。它有两条分支路径可选,一条是条件为真,执行块,另一条是条件不满足,跳过块。

如,计算x 的绝对值,根据绝对值定义,我们知道,当x>=0时,其绝对值不变,而x

if(x

x=-x;

②if(条件)

{块1}

else

{块2}

这是典型的分支结构,如果条件成立,执行块1,否则执行块2,块1和块2都有1条或若干条语句构成。

如:求ax^2+bx+c=0的根

分析:因为当b^2-4ac>=0时, 方程有两个实根,否则(b^2-4ac

d=b*b-4*a*c;

if(d>=0)

{ x1=(-b+sqrt(d))/2a;

x1=(-b-sqrt(d))/2a;

printf(“x1=%8.4f,x2=%8.4f\n”,x1,x2);

}

else

{r=-b/(2*a);

i =sqrt(-d)/(2*a);

printf(“x1=%8.4f+%8.4fi\n”r, i);

printf(“x2=%8.4f-%8.4fi\n”r,i)

}

③多路分支:其语句格式为:

if(条件1) {块1};

else if(条件2) {块2}

else if(条件3) {块3}

„„

else if(条件n ) {块n}

else {块n+1}

④switch语句:

switch

语句也是多分支选择语句,又称为多路开关语句,到底执行哪一块,取决于开关设置,也就是表达式的值与常量表达式相匹配的那一路,它不同if―else 语句,它的所有分支都是并列的,程序执行时,由第一分支开始查找,如果相匹配,执行其后的块,接着执行第2分支,第3分支„„的块,直到遇到break 语句;如果不匹配,查找下一个分支是否匹配。

(3)循环结构:

循环结构可以减少源程序重复书写的工作量,用来描述重复执行某段算法的问题,这是程序设计中最能发挥计算机特长的程序结构,C 语言中提供四种循环,即goto 循环、while 循环、do ...while循环和for 循环。

四种循环可以用来处理同一问题,一般情况下它们可以互相代替换,但一般不提昌用goto 循环,所以下面我们重点讲解另外的三种循环。

常用的三种循环结构学习的重点在于弄清它们相同与不同之处,以便在不同场合下使用,大家好好看一下书中三种循环的格式和执行顺序,如何替换使用,如把while 循环的例题,用for 语句重新编写一个程序,这样能更好地理解它们的作用。

注意:在while 和do―while循环体内和for

循环中的第3语句中,应包含趋于结束的语句(如I++,I--),否则就可能成了

一个死循环,这也是初学者的一个常见错误。

下面我们来讨论下这三种循环的异同之处:

用while 和do―while循环时,循环变量的初始化的操作应在循环体之前,而for 循环是在语句1中进行的;while 循环和for 循环都是先判断表达式,后执行循环体,而do―while循环是先执行循环体后判断表达式,也就是说do―while的循环体最少被执行一次,而while 循环和for 就不一定了。这三种循环都可以用break 语句跳出循环,用continue 语句结束本次循环,而goto 语句与if 构成的循环,不能用break 和 continue语句进行控制。

这三种结构并不是彼此孤立的,在循环中可能出现分支、顺序结构,分支中也可能出现循环、顺序结构而把循环、分支看成一个语句,它又是构成顺序结构的一个元素,因此这三种结构相互结合,就能实现各种算法,设计出解题程序,但若是很大的题目,这样编出的程序往往很长,重复结构多,并且可阅读性差,因此我们常将C 程序设计成模块化结构。

(4)模块化程序结构

C 语言的模块化程序结构用函数来实现,即将复杂的C 程序分为若干模块,每个模块都编写成一个合法的C 函数,然后用主函数调用函数及函数调用函数实现一大C 程序:C 程序=主函数(main )+若干个函数。

在程序设计中,常将一些常用的功能模块写成函数,也可以将大程序段分割成若干函数,前者目的在于减少重复编写程序段的工作量,后者目的在于缩短模块长度,以便程序阅读方便。

一个源程序文件由一个或多个函数组成,它是一个编译单位,而一个C 程序由一个或多个源程序文件组成。对较大的程序,往往分成多个文件,这样可以分别编写、分别编译,提高高调试效率,一个源程序文件可以被多个C 程序公用。

C 程序的的执行是从main()函数开始,调用其它函数后流程回到main 函数,在main 中结束整个函数运行,main 函数的称是系统规定的,用户可以修改其内容即函数体,但不能修改其名称和参数,一个C 程序必须有一个main 函数,也只能有一个main 函数。

所有函数都是平行的,即在定义函数时是互相独立的一个函数度不从属于另一个函数,即函数不能嵌套定义,但可以互相调用,但不能调用main 函数。

函数分成两类,即标准函数和用户自定义函数,标准函数又称库函数,由系统提供,用户可直接调用,C 语言提供了丰富的库函数,请考生在编写C 程序时查阅教材后的函数说明,这可节省你的编程工作量;用户自定义函数由编程者自己编写.

如何学习C 语言的四种程序结构

1)顺序结构

2)分支结构

3)循环结构

4) 模块化程序结构

(1)顺序结构

这种结构的程序比较简单,就是按照语句的排列顺序依次执行的机制。顺序结构的执行顺序是自上而下,依次执行,因此编写程序也必须遵守这一规定,否则你的程序执行结果就不对。

例如;a = 3,b = 5,现交换a ,b 的值,正确的程序为:

c = a; a = b; b = c;

执行结果是a = 5,b = c = 3如果改变其顺序,写成:

a = b; c = a; b = c;

则执行结果就变成a = b = c = 5,不能达到预期的目的,这是初学者常犯的错误。

顺序结构可以独立使用构成一个简单的完整程序,常见的输入、计算,输出三步曲的程序就是顺序结构,例如计算圆的面积,其程序的语句顺序就是输入圆的半径R ,计算S = 3.14159*R*R,输出圆的面积S 。而大多数情况下顺序结构都是作为程序的一部分,与其它结构一起构成一个复杂的程序,例如分支结构中的块体、循环结构中的循环体等。

(2) 分支结构

分支结构与顺序结构不同,其执行是依据一定的条件选择执行路径,而不是严格按照语句出现的物理顺序。分支结构的程序设计方法的关键在于构造合适的分支条件和分析程序流程,根据不同的程序流程选择适当的分支语句。

分支结构适合于带有逻辑条件判断的计算,设计这类程序时往往都要先绘制其程序流程图,然后根据程序流程写出源程序,这样做把程序设计分析与语言分开,使得问题简单化,易于理解。程序流程图是根据解题分析所绘制的程序执行流程图。

学习分支结构不要被分支嵌套所迷惑,只要弄清基本的分支结构,嵌套结构也就不难了。嵌套只不过是分支块体中又包括分支语句而已,不是新知识,只要你基础知识扎实,分支嵌套也难不住你,下面我们重点讨论几种基本的分支结构的学习方法。

①If(条件)

{

}

这种分支结构中的块可以是一条语句,此时“{ }”可以省略,也可以是多条语句。它有两条分支路径可选,一条是条件为真,执行块,另一条是条件不满足,跳过块。

如,计算x 的绝对值,根据绝对值定义,我们知道,当x>=0时,其绝对值不变,而x

if(x

x=-x;

②if(条件)

{块1}

else

{块2}

这是典型的分支结构,如果条件成立,执行块1,否则执行块2,块1和块2都有1条或若干条语句构成。

如:求ax^2+bx+c=0的根

分析:因为当b^2-4ac>=0时, 方程有两个实根,否则(b^2-4ac

d=b*b-4*a*c;

if(d>=0)

{ x1=(-b+sqrt(d))/2a;

x1=(-b-sqrt(d))/2a;

printf(“x1=%8.4f,x2=%8.4f\n”,x1,x2);

}

else

{r=-b/(2*a);

i =sqrt(-d)/(2*a);

printf(“x1=%8.4f+%8.4fi\n”r, i);

printf(“x2=%8.4f-%8.4fi\n”r,i)

}

③多路分支:其语句格式为:

if(条件1) {块1};

else if(条件2) {块2}

else if(条件3) {块3}

„„

else if(条件n ) {块n}

else {块n+1}

④switch语句:

switch

语句也是多分支选择语句,又称为多路开关语句,到底执行哪一块,取决于开关设置,也就是表达式的值与常量表达式相匹配的那一路,它不同if―else 语句,它的所有分支都是并列的,程序执行时,由第一分支开始查找,如果相匹配,执行其后的块,接着执行第2分支,第3分支„„的块,直到遇到break 语句;如果不匹配,查找下一个分支是否匹配。

(3)循环结构:

循环结构可以减少源程序重复书写的工作量,用来描述重复执行某段算法的问题,这是程序设计中最能发挥计算机特长的程序结构,C 语言中提供四种循环,即goto 循环、while 循环、do ...while循环和for 循环。

四种循环可以用来处理同一问题,一般情况下它们可以互相代替换,但一般不提昌用goto 循环,所以下面我们重点讲解另外的三种循环。

常用的三种循环结构学习的重点在于弄清它们相同与不同之处,以便在不同场合下使用,大家好好看一下书中三种循环的格式和执行顺序,如何替换使用,如把while 循环的例题,用for 语句重新编写一个程序,这样能更好地理解它们的作用。

注意:在while 和do―while循环体内和for

循环中的第3语句中,应包含趋于结束的语句(如I++,I--),否则就可能成了

一个死循环,这也是初学者的一个常见错误。

下面我们来讨论下这三种循环的异同之处:

用while 和do―while循环时,循环变量的初始化的操作应在循环体之前,而for 循环是在语句1中进行的;while 循环和for 循环都是先判断表达式,后执行循环体,而do―while循环是先执行循环体后判断表达式,也就是说do―while的循环体最少被执行一次,而while 循环和for 就不一定了。这三种循环都可以用break 语句跳出循环,用continue 语句结束本次循环,而goto 语句与if 构成的循环,不能用break 和 continue语句进行控制。

这三种结构并不是彼此孤立的,在循环中可能出现分支、顺序结构,分支中也可能出现循环、顺序结构而把循环、分支看成一个语句,它又是构成顺序结构的一个元素,因此这三种结构相互结合,就能实现各种算法,设计出解题程序,但若是很大的题目,这样编出的程序往往很长,重复结构多,并且可阅读性差,因此我们常将C 程序设计成模块化结构。

(4)模块化程序结构

C 语言的模块化程序结构用函数来实现,即将复杂的C 程序分为若干模块,每个模块都编写成一个合法的C 函数,然后用主函数调用函数及函数调用函数实现一大C 程序:C 程序=主函数(main )+若干个函数。

在程序设计中,常将一些常用的功能模块写成函数,也可以将大程序段分割成若干函数,前者目的在于减少重复编写程序段的工作量,后者目的在于缩短模块长度,以便程序阅读方便。

一个源程序文件由一个或多个函数组成,它是一个编译单位,而一个C 程序由一个或多个源程序文件组成。对较大的程序,往往分成多个文件,这样可以分别编写、分别编译,提高高调试效率,一个源程序文件可以被多个C 程序公用。

C 程序的的执行是从main()函数开始,调用其它函数后流程回到main 函数,在main 中结束整个函数运行,main 函数的称是系统规定的,用户可以修改其内容即函数体,但不能修改其名称和参数,一个C 程序必须有一个main 函数,也只能有一个main 函数。

所有函数都是平行的,即在定义函数时是互相独立的一个函数度不从属于另一个函数,即函数不能嵌套定义,但可以互相调用,但不能调用main 函数。

函数分成两类,即标准函数和用户自定义函数,标准函数又称库函数,由系统提供,用户可直接调用,C 语言提供了丰富的库函数,请考生在编写C 程序时查阅教材后的函数说明,这可节省你的编程工作量;用户自定义函数由编程者自己编写.


相关内容

  • 侦查程序结构论
  • 作者:陈岚 法学评论 2000年02期 历史进入本世纪五十年代,社会科学研究领域发生了引人瞩目的变化,其标志为结构主义的悄然兴起.(注:结构主义起于何时,尚存争议.其在法国的广泛应用是本世纪六十年代的事.参见盛晓明主编:<古今西方哲学教程>,浙江大学出版社1989年10月版,第505-5 ...

  • 程序设计方法学
  • 程序设计方法学 程序设计方法学是指用以指导程序设计各阶段工作的原理和原则,以及依此提出的设计技术.有时也指研究这些原理.原则和技术的学科.程序设计方法学的目标是能设计出可靠.易读而且代价合理的程序.程序设计方法学包括程序理论.研制技术.支援环境.工程规范和自动程序设计等课题,使程序设计更加科学化和工 ...

  • 程序设计基础(知识点)
  • 第三部分 程序设计基础 3.1 程序.程序设计.程序设计语言的定义 ⑴程序:计算机程序,是指为了得到某种结果而可以由计算机等具有信息处理能力的装置执行的代码化指令序列,或者可以被自动转换成代码化指令序列的符号化指令序列或者符号化语句序列. ⑵程序设计:程序设计是给出解决特定问题程序的过程,是软件构造 ...

  • [高级语言程序设计]
  • <高级语言程序设计>教学大纲 王林平 编 一.总则 1. 教学目的与要求 (1)教学目的 <高级语言程序设计>是学习研究计算机及其应用的一门很重要的专业基础课程.它为<数据结构>.<操作系统>等其它专业基础课或专业课程奠定程序设计的基础,又是其它专业课 ...

  • 程序设计方法学01
  • 天津师范大学计算机与信息工程学院 硕士研究生课程讲义 程序设计方法学 课程介绍 „ 任课老师信息 • 姓名:朱远平 • Email:[email protected] „ 课程信息 • 课程名:程序设计方法学 • 学分:3 • 课程目的 – 学习程序设计的基本概念.原理.方法 ...

  • 程序与程序设计语言
  • 程序与程序设计语言 一.教学目标 1.知识与技能 (1)理解程序的概念.特征和三种基本结构. (2)理解程序的编辑和翻译的意义. 2.方法与过程 掌握程序的编辑技能和方法 3. 情感态度和价值观 关注程序设计的意义.关注程序设计语言的发展. 二.重点难点 理解程序的概念.特征和三种基本结构.掌握程序 ...

  • labview实践出真知
  • 第二章 强筋健骨:由程序流程的控制展开 按照通常的教程,现在一般要介绍各种数据类型,例如数字.字符串.数组与簇等等.不过从程序结构入手,在掌握流程控制VI的同时认识各数据类型应该更有效,毕竟如果老是把目光集中在树木上,那很容易忘了郁郁葱葱的森林. 本章仍然通过实例来学习,依次完成For循环.Whil ...

  • pkpm课程总结
  • Pkpm课程总结 一.PKPM的发展方向 PKPM程序的发展方向主要有两个方面: ●一个方面就是计算,它的方向就是集成化.通用化.集成化大家都能感觉到,PKPM程序都是以PM程序所建数据为条件,以空间计算为核心,基础.后期的CAD出图都能采用前面的数据.所有这些都构成了程序集成化的雏形.程序的通用化 ...

  • 第3讲 基本设计与详细设计
  • 第三讲 软件设计 大连海事大学计算机学院软件工程研究室 蒋 波 软件设计阶段要解决的问题是"How to do"的问题.就是说,需将整个系统划分出系统的物理组成元素(程序.文件.DB.人工过程.文档). 软件设计分为基本设计和详细设计两个部分.基本设计的主要工作是确定系统的结构. ...