第七章 用函数实现模块化程序设计_第1页
第七章 用函数实现模块化程序设计_第2页
第七章 用函数实现模块化程序设计_第3页
第七章 用函数实现模块化程序设计_第4页
第七章 用函数实现模块化程序设计_第5页
已阅读5页,还剩66页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、电电气气与与信信息息工工程程学学院院第七章第七章 用函数实现模块化程序设计用函数实现模块化程序设计电电气气与与信信息息工工程程学学院院2void main() : x=x*x*x; y=y*y*y; z=z*z*z; ans1=x+y+z; a=a*a*a; b=b*b*b; c=c*c*c; ans2=a+b+c; :重复多次的同一计算类型void main() : ans1=cube(x,y,z); ans2=cube(a,b,c); :int cube(int a,b,c) int ans; ans=(a*a*a)+(b*b*b)+(c*c*c); return ans;函数主程序ans

2、函数可以把相对独立的某个功能抽象出来,使之成为程序中的一个独立实体。可以在同一个程序或其他程序中多次重复使用电电气气与与信信息息工工程程学学院院3q模块化程序设计模块化程序设计q基本思想:将一个大的程序按功能分割成一些小模块基本思想:将一个大的程序按功能分割成一些小模块,q特点:特点:各模块相对独立、功能单一、结构清晰、接口简各模块相对独立、功能单一、结构清晰、接口简单单控制了程序设计的复杂性控制了程序设计的复杂性提高元件的可靠性提高元件的可靠性缩短开发周期缩短开发周期避免程序开发的重复劳动避免程序开发的重复劳动易于维护和功能扩充易于维护和功能扩充q开发方法开发方法: 自上向下自上向下,逐步分

3、解,分而治之逐步分解,分而治之电电气气与与信信息息工工程程学学院院4函数机制的优点q使程序变得更简短而清晰 q有利于程序维护q可以提高程序开发的效率 q提高了代码的重用性 电电气气与与信信息息工工程程学学院院5qC是模块化程序设计语言是模块化程序设计语言 源程序文件1预编译命令说明部分执行部分函数1函数n源程序文件i源程序文件nC程序C程序结构电电气气与与信信息息工工程程学学院院6函数类型 库函数:由语言系统提供;用户无须定义,也不必在程序中作类型说明;只需在程序前包含有该函数定义的头文件; 自定义函数:用户在程序中根据需要而编写的函数;电电气气与与信信息息工工程程学学院院7问题描述:求自然数

4、110的平方根和立方。 内置函数sqrt 和pow 示例2664#include #include void main() int x=1; double squareroot,power; while(x y?x:y; return m;该函数名为displayDiscount,无参数,使用void说明无返回值,函数体内的语句用于根据产品的价格求折扣后的价格。该函数名为max,它有两个double类型的参数,返回值为double类型。在函数体内有三条语句实现了求两个数中较大的数,并将它返回。电电气气与与信信息息工工程程学学院院9q一般格式一般格式合法标识符函数返回值类型缺省int型无返回值v

5、oid函数体函数类型函数类型 函数名(形参类型说明表)函数名(形参类型说明表) 说明部分说明部分语句部分语句部分 现代风格现代风格: : 有参函数(现代风格) int max(int x,int y) int z; z=xy?x:y; return(z); 有参函数(现代风格) int max(int x, y) int z; z=xy?x:y; return(z); 空函数 dummy( ) 函数体为空无参函数 printstar( ) printf(“*n”); 或 printstar(void ) printf(“*n”); 形式参数表形式参数表: :是用逗号分开的一组变量,是用逗号分开

6、的一组变量,用来接收调用时传入的数据。用来接收调用时传入的数据。电电气气与与信信息息工工程程学学院院10int divisibleCheck(int num) if (num % 5 = 0) return 1; else return 0; C语言中的函数至多可以返回一个值,不能返回多个值; 返回值的数据类型必须与函数原型中返回值的数据类型匹配; 当遇到 return 语句时,函数执行将终止。程序控制流将立即返回调用函数;函数返回值qC 语言中的 return 语句用于向调用函数返回值,语法如下: return (); 电电气气与与信信息息工工程程学学院院11q 返回语句返回语句q形式:形式

7、: return(表达式表达式); 或或 return 表达式表达式; 或或 return;q功能:使程序控制从被调用函数返回到调用函数中,同时把返功能:使程序控制从被调用函数返回到调用函数中,同时把返值带给调用函数值带给调用函数q说明:说明:函数中可有多个函数中可有多个return语句语句若无若无return语句,遇语句,遇时,自动返回调用函数时,自动返回调用函数若函数类型与若函数类型与return语句中表达式值的类型不一语句中表达式值的类型不一致,按前者为准,自动转换致,按前者为准,自动转换-函数调用转换函数调用转换void型函数型函数例:无返回值函数 void swap(int x,in

8、t y ) int temp; temp=x; x=y; y=temp; 电电气气与与信信息息工工程程学学院院12 printstar() printf(*);main() int a; a=printstar(); printf(%d,a);例:函数带回不确定值输出:10void printstar() printf(*);main() int a; a=printstar(); printf(%d,a);编译错误!编译错误!电电气气与与信信息息工工程程学学院院13例:函数返回值类型转换main() float a,b; int c; scanf(%f,%f,&a,&b); c=max(a,

9、b); printf(Max is %dn,c);max(float x, float y) float z; z=xy?x:y; return(z);电电气气与与信信息息工工程程学学院院14函数返回值示例#include int get_age();void main() int age1, age2, age3; age1 = get_age(); age2 = get_age(); age3 = get_age(); if ( (age1 age2) & (age1 age3) printf(n年龄为 %d 的人最大n, age1); else if( (age2 age1) & (ag

10、e2 age3)printf(n年龄为 %d 的人最大n, age2); else if( (age3 age1) & (age3 age2)printf(n年龄为 %d 的人最大n, age2);内存age1age26578age3int get_age() int age; printf(n请输入年龄: ); scanf(%d,&age); return age;请输入年龄:65请输入年龄:78请输入年龄:54年龄为 78 岁的人最大54电电气气与与信信息息工工程程学学院院15q 函数是函数是C程序的最小单元。程序的最小单元。q C程序是由一个主函数以及若干个函数构成。程序是由一个主函数以

11、及若干个函数构成。q 主函数可以调用其它函数,其它函数可以相互调用。主函数可以调用其它函数,其它函数可以相互调用。q必须有且只能有一个名为main的主函数qC程序的执行总是从main函数开始,在main中结束q 例如:例如:main()main() printf(“Thisprintf(“This is C programn”); is C programn”); 就是就是 mainmain 函数调用了函数调用了 printfprintf 函数。函数。printfprintf函函数是一个库函数。为了完成一个特定的任务,在数是一个库函数。为了完成一个特定的任务,在程序开发中一般要定义若干函数。程

12、序开发中一般要定义若干函数。电电气气与与信信息息工工程程学学院院16q 函数分类函数分类q从用户角度从用户角度标准函数(库函数):由系统提供标准函数(库函数):由系统提供用户自定义函数用户自定义函数q从函数形式从函数形式无参函数无参函数有参函数有参函数使用库函数应注意:1、函数功能2、函数参数的数目和顺序,及各参数意义和类型3、函数返回值意义和类型4、需要使用的包含文件包含文件电电气气与与信信息息工工程程学学院院17q 通过在程序中使用函数名称,可以执行函数中包含的语句,这称为调用函数q 函数之间允许相互调用,也允许嵌套调用q 函数还可以自己调用自己,称为递归调用#includevoid ma

13、in():set_discount();displayDiscount();:float set_discount() : :float displayDiscount() : :7.3调用函数调用函数电电气气与与信信息息工工程程学学院院18问题描述:根据用户的选择求不同形状的面积。函数调用示例#includevoid AreaOfRect();void AreaOfTriangle();void AreaOfRound();void main() int select; do printf( 0、退出n 1、长方形n 2、三角形n 3、圆形n);printf(请选择功能:);scanf(%d

14、,&select);if(select = 0) break;switch(select) case 1 : AreaOfRect(); break; /长方形 case 2 : AreaOfTriangle(); break; /三角形 case 3 : AreaOfRound(); break; /圆形 default : printf(输入有误,请在 04 之间选择。n); while(1);void AreaOfRect() int x,y; printf(请输入长方形的长:); scanf(%d,&x); printf(请输入长方形的宽:); scanf(%d,&y); printf

15、(面积为:%dn,(x * y); void AreaOfTriangle() int x,y; printf(请输入三角形的底:); scanf(%d,&x); printf(请输入三角形的高:); scanf(%d,&y); printf(面积为:%dn,(x * y)/2); void AreaOfRound() int r; printf(请输入圆形的半径:); scanf(%d,&r); printf(面积为:%dn,3.14*r*r); 函数原型演示:示例6电电气气与与信信息息工工程程学学院院19q调用形式调用形式 函数名函数名(实参表实参表);说明:说明:实参与形参实参与形参个数

16、相等,类型一致,按顺序一一对应个数相等,类型一致,按顺序一一对应实参表求值顺序,因系统而定(实参表求值顺序,因系统而定(Turbo C 自右向左自右向左)函数调用函数调用时,可以使用时,可以使用参数参数、返回值返回值、全全局变量局变量等方式在不同的函数之间传递数据。等方式在不同的函数之间传递数据。电电气气与与信信息息工工程程学学院院20main() int i=2,p; p=f(i,+i); printf(%d,p);int f(int a, int b) int c; if(ab) c=1; else if(a=b) c=0; else c=-1; return(c);例例:参数求值顺序参数

17、求值顺序main() int i=2,p; p=f(i, i+); printf(%d,p);int f(int a, int b) int c; if(ab) c=1; else if(a=b) c=0; else c=-1; return(c);运行结果:0运行结果:1电电气气与与信信息息工工程程学学院院21q调用方式调用方式q函数语句:函数语句: 例例:printstar(); printf(“Hello,World!n”);q函数表达式:函数表达式: 例例:m=max(a,b)*2;q函数参数:函数参数: 例例:printf(“%d”,max(a,b); m=max(a,max(b,c

18、);电电气气与与信信息息工工程程学学院院22q函数参数及其传递方式函数参数及其传递方式q形参与实参形参与实参q形式参数:定义函数时函数名后面括号中的变量名形式参数:定义函数时函数名后面括号中的变量名q实际参数:调用函数时函数名后面括号中的表达式实际参数:调用函数时函数名后面括号中的表达式c=max(a,b); (main 函数)函数) (max 函数)函数)max(int x, int y) int z; z=xy?x:y; return(z); 例例: 比较两个数并输出大者比较两个数并输出大者main() int a,b,c; scanf(%d,%d,&a,&b); c=max(a,b);

19、printf(Max is %d,c);max(int x, int y) int z; z=xy?x:y; return(z);形参形参实参实参电电气气与与信信息息工工程程学学院院23q说明:说明:实参必须有确定的值实参必须有确定的值形参必须指定类型形参必须指定类型形参与实参形参与实参类型一致,个数相同类型一致,个数相同若形参与实参类型不一致,自动按形参类型转若形参与实参类型不一致,自动按形参类型转换换函数调用转换函数调用转换形参在函数被调用前不占内存形参在函数被调用前不占内存;函数调用时为形参函数调用时为形参分配内存;调用结束,内存释放分配内存;调用结束,内存释放q形参与实参q形式参数:定

20、义函数时函数名后面括号中的变量名形式参数:定义函数时函数名后面括号中的变量名q实际参数:调用函数时函数名后面括号中的表达式实际参数:调用函数时函数名后面括号中的表达式电电气气与与信信息息工工程程学学院院24例例:计算计算x的立方的立方#include float cube(float x) return(x*x*x);main() float a, product; printf(Please input value of a:); scanf(%f,&a); product=cube(a); printf(”Cube of %.4f is %.4fn,a,product);xaproduct

21、28电电气气与与信信息息工工程程学学院院25q参数传递方式参数传递方式q值传递值传递方式方式方式:函数调用时方式:函数调用时,为形参分配单元为形参分配单元,并将实参的值并将实参的值复制复制到形参中;调用结束,形参单元被释放,实参到形参中;调用结束,形参单元被释放,实参单元仍保留并维持原值单元仍保留并维持原值特点:特点:形参与实参占用形参与实参占用不同不同的内存单元的内存单元单向单向传递传递电电气气与与信信息息工工程程学学院院26711x:y:调用前:调用结束:711x:y: 交换两个数#include main() int x=7,y=11; printf(x=%d,ty=%

22、dn,x,y); printf(swapped:n); swap(x,y); printf(x=%d,ty=%dn,x,y);swap(int a,int b) int temp; temp=a; a=b; b=temp;调用:711a:b:711x:y:swap:711x:y:117a:b:temp电电气气与与信信息息工工程程学学院院27q地址传递地址传递方式:函数调用时,将数据的方式:函数调用时,将数据的存储地址存储地址作为参数作为参数传递给形参传递给形参特点:特点:形参与实参占用形参与实参占用同样同样的存储单元的存储单元“双向双向”传递传递实参和形参必须是实参和形参必须是地址地址常量或变

23、量常量或变量 参数传递方式参数传递方式 值传递值传递方式方式 数组名作函数参数数组名作函数参数地址传递地址传递在主调函数与被调函数分别定义数组在主调函数与被调函数分别定义数组,且类且类型应一致型应一致形参数组大小形参数组大小(多维数组第一维多维数组第一维)可不指定可不指定形参数组名是形参数组名是地址变量地址变量电电气气与与信信息息工工程程学学院院28例例:数组元素与数组名数组元素与数组名 作函数参数比较作函数参数比较12a调用前a0a112a调用a0a112xy21xy交换12a返回#include void swap2(int x,int y) int z; z=x; x=y; y=z;ma

24、in() int a2=1,2; swap2(a0,a1); printf(a0=%dna1=%dn,a0,a1);值传递值传递电电气气与与信信息息工工程程学学院院2912a调用前12ax调用21ax交换21a返回地址传递例例:数组元素与数组元素与 数组名数组名 作函数参数比较作函数参数比较#include void swap2(int x) int z; z=x0; x0=x1; x1=z;main() int a2=1,2; swap2(a); printf(a0=%dna1=%dn,a0,a1);例例: :数组排序数组排序-简单选择排序简单选择排序void sort(int array,

25、int n) int i,j,k,t; for(i=0;in-1;i+) k=i; for(j=i+1;jn;j+) if(arrayjarrayk) k=j; if(k!=i) t=arrayi; arrayi=arrayk; arrayk=t; main() int a10,i; for(i=0;i10;i+)scanf(%d,&ai); sort(a,10); for(i=0;i10;i+) printf(%d ,ai); printf(n);0123456789a4968573299927137688arraykjjjkjkjjjjj949i=0例例: :数组排序数组排序-简单选择排序

26、简单选择排序void sort(int array,int n) int i,j,k,t; for(i=0;in-1;i+) k=i; for(j=i+1;jn;j+) if(arrayjarrayk) k=j; if(k!=i) t=arrayi; arrayi=arrayk; arrayk=t; main() int a10,i; for(i=0;i10;i+)scanf(%d,&ai); sort(a,10); for(i=0;i10;i+) printf(%d ,ai); printf(n);kjjkjkjjjjj0123456789a4968573299927137688array9

27、49kk1368i=10123456789a9132732495768768899arrayi=8例例: :数组排序数组排序-简单选择排序简单选择排序void sort(int array,int n) int i,j,k,t; for(i=0;in-1;i+) k=i; for(j=i+1;jn;j+) if(arrayjarrayk) k=j; if(k!=i) t=arrayi; arrayi=arrayk; arrayk=t; main() int a10,i; for(i=0;i10;i+)scanf(%d,&ai); sort(a,10); for(i=0;i10;i+) prin

28、tf(%d ,ai); printf(n);电电气气与与信信息息工工程程学学院院33函数原型#include float count (int, int);void main() . . . . . .float count(int x,int y) . . .q 函数原型说明在形式上与函数头部类似,最后加一个分号。原型说明中参数表里的参数名可以不写(只写参数类型)。q 在C语言程序中用到的所有函数,必须“先定义,后使用”q 指定函数名字、函数返回值类型、函数实现的功能以及参数的个数与类型,将这些信息通知编译系统。7.4对被调函数的声明和函数原对被调函数的声明和函数原型型q函数说明函数说明q对

29、被调用函数要求:对被调用函数要求: 必须是必须是已存在已存在的函数的函数 库函数库函数: #include 用户自定义函数用户自定义函数: 函数类型说明函数类型说明q函数说明函数说明 一般形式:一般形式: 函数类型函数类型 函数名函数名(形参类型形参类型 形参名形参名,. ); 或或 函数类型函数类型 函数名函数名(); 作用:告诉编译系统作用:告诉编译系统函数类型、参数个数及类型,以便检验函数类型、参数个数及类型,以便检验 函数定义函数定义与与函数说明函数说明不同不同 函数说明位置:函数说明位置:程序的数据说明部分(函数内或外)程序的数据说明部分(函数内或外) 下列情况下,可不作函数说明下列

30、情况下,可不作函数说明 若函数返值是若函数返值是char或或int型型,系统自动按,系统自动按int型处理型处理 被调用函数定义出现在主调函数之前被调用函数定义出现在主调函数之前 有些系统有些系统(如如Borland C+)要求函数说明指出函数返值类型和要求函数说明指出函数返值类型和形参类型,并且对形参类型,并且对void 和和 int 型函数也要进行函数说明型函数也要进行函数说明电电气气与与信信息息工工程程学学院院35例例:函数说明举例函数说明举例main() float a,b; int c; scanf(%f,%f,&a,&b); c=max(a,b); printf(Max is %d

31、n,c);max(float x, float y) float z; z=xy?x:y; return(z);int型函数可不作函数说明(Borland C+不行)float add(float x, float y) float z; z=x+y; return(z);main() float a,b,c; scanf(%f,%f,&a,&b); c=add(a,b); printf(sum is %f,c);被调函数出现在主调函数之前,不必函数说明main() float add(float,float); /*function declaration*/ float a,b,c; sc

32、anf(%f,%f,&a,&b); c=add(a,b); printf(sum is %f,c);float add(float x, float y) float z; z=x+y; return(z);float add();电电气气与与信信息息工工程程学学院院36#include long sum(int a, int b); long factorial(int n);main() int n1,n2; long a; scanf(%d,%d,&n1,&n2); a=sum(n1,n2); printf(a=%1d,a); long sum(int a,int b) long c1,

33、c2; c1=factorial(a); c2=factorial(b); return(c1+c2); long factorial(int n) long rtn=1; int i; for(i=1;i=n;i+) rtn*=i; return(rtn); long sum(int a, int b);long factorial(int n);文件包含编译预处理命令函数类型说明函数定义函数调用函数调用函数返回值形参实参电电气气与与信信息息工工程程学学院院37void reverse() : :#includevoid main():palindrome();:void palindrom

34、e() : reverse(); :7.5函数的嵌套调用函数的嵌套调用从一个函数调用另一个函数称为函数的嵌套调用 电电气气与与信信息息工工程程学学院院38C规定:规定:函数定义不可嵌套函数定义不可嵌套,但,但可以嵌套调用可以嵌套调用函数函数电电气气与与信信息息工工程程学学院院39求两个正整数求两个正整数a a、b b的最小公倍数。的最小公倍数。 最 最小公倍数可按下面的公式求出: 最小公倍数=的最大公约数和baba 若要求最小公倍数则必先求最大公约数 可分别用三个函数实现各部分功能(1) 用函数hcf(m,n)求m,n的最大公约数;(2) 用函数lcd(x,y)求x,y的最小公倍数;(3) 在

35、主函数中进行输入和输出;电电气气与与信信息息工工程程学学院院40int hcf(int m,int n)int t,r;r=m%n;while(r!=0) m=n; n=r; r=m%n; return(n);int lcd(int x,int y) int h,l; h=hcf(x,y); l=(x*y)/h; return(l); main() int s,a,b; scanf(%d%d,&a,&b); s=lcd(a,b); printf(最小公倍数为:d,s); 设输入为98 和32则x=98 y=32则m=98 n=32返回4电电气气与与信信息息工工程程学学院院41int hcf(i

36、nt m,int n)int t,r;r=m%n;while(r!=0) m=n; n=r; r=m%n; return(n);int lcd(int x,int y) int h,l; h=hcf(x,y); l=(x*y)/h; return(l); main() int s,a,b; scanf(%d%d,&a,&b); s=lcd(a,b); printf(最小公倍数为:d,s); 设输入为98 和32则x=98 y=32h=4返回返回784电电气气与与信信息息工工程程学学院院42int lcd(int x,int y) int h,l; h=hcf(x,y); l=(x*y)/h;

37、return(l); main() int s,a,b; scanf(%d%d,&a,&b); s=lcd(a,b); printf(最小公倍数为:d,s); 设输入为98 和32int hcf(int m,int n)int t,r;r=m%n;while(r!=0) m=n; n=r; r=m%n; return(n);s=784电电气气与与信信息息工工程程学学院院43例:求三个数中最大数和最小数的差值#include int dif(int x,int y,int z); int max(int x,int y,int z); int min(int x,int y,int z);voi

38、d main() int a,b,c,d; scanf(%d%d%d,&a,&b,&c); d=dif(a,b,c); printf(Max-Min=%dn,d); int dif(int x,int y,int z) return max(x,y,z)-min(x,y,z); int max(int x,int y,int z) int r; r=xy?x:y; return(rz?r:z); int min(int x,int y,int z) int r; r=xy?x:y; return(rz?r:z); main( )调用函数dif输出结束dif函数max函数调用函数max调用函数m

39、inmin函数电电气气与与信信息息工工程程学学院院44例:用弦截法求方程根例:用弦截法求方程根08016523xxxxyf(x)0 x1x2xf(x1)f(x2)()()()(121221xfxfxfxxfxx略过略过电电气气与与信信息息工工程程学学院院45求f(x1)与f(x2)连线与x轴的交点x输入x1,x2,求f(x1),f(x2)直到f(x1)与f(x2)异号y=f(x),y1=f(x1)y与y1同号真假x1=xy1=yx2=x直到 |y|root=x 输出 rootroot函数运行情况:Input x1,x2:2,6A root of equation is 5.0000main(

40、)调用函数root输出根 x结束root函数xpoint函数调用函数xpoint调用函数ff函数电电气气与与信信息息工工程程学学院院46/* 此函数用于计算 a 的阶乘 */int factorial(int a) if (a = 1) return 1; else a = a * factorial(a-1); return a; 在一个函数体内调用自身称为函数的递归调用 7.6函数的递归调用函数的递归调用电电气气与与信信息息工工程程学学院院47q定义:函数直接或间接的调用自身叫函数的递归调用定义:函数直接或间接的调用自身叫函数的递归调用f( )调f调f2调f1f1( )f2( )q说明说明

41、 C编译系统对递归函数的自调用次数没有限制编译系统对递归函数的自调用次数没有限制 每调用函数一次,在内存堆栈区分配空间,用于存放函数变每调用函数一次,在内存堆栈区分配空间,用于存放函数变量、返回值等信息,所以递归次数过多,可能引起堆栈溢出量、返回值等信息,所以递归次数过多,可能引起堆栈溢出int f(int x) int y,z; z=f(y); . return(2*z);int f1(int x) int y,z; z=f2(y); . return(2*z);int f2(int t) int a,c; c=f1(a); . return(3+c);电电气气与与信信息息工工程程学学院院4

42、8例:求例:求n的阶乘的阶乘) 1()!1() 1 , 0(1!nnnnnfac(int n) int f; if(n0) printf(n0,data error!); else if(n=0|n=1) f=1; else f=fac(n-1)*n; return(f);main() int n, y; printf(Input a integer number:); scanf(%d,&n); y=fac(n); printf(%d! =%15d,n,y);int fac(int n) int f; if(n0) printf(n0,data error!); else if(n=0|n=

43、1) return(1); else return (f=fac(n-1)*n);电电气气与与信信息息工工程程学学院院49fac(int n) int f; if(n0) printf(n0,data error!); else if(n=0|n=1) f=1; else f=fac(n-1)*n; return(f);main() int n, y; printf(Input a integer number:); scanf(%d,&n); y=fac(n); printf(%d! =%15d,n,y);设输入n为4n=4fac(3)n=3电电气气与与信信息息工工程程学学院院50n n4

44、4= = 44fac(int n) int f; if(n0) printf(n0,data error!); else if(n=0|n=1) f=1; else f=fac(n-1)*n; return(f);fac(int n) int f; if(n0) printf(n0,data error!); else if(n=0|n=1) f=1; else f=fac(n-1)*n; return(f);fac(int n) int f; if(n0) printf(n0,data error!); else if(n=0|n=1) f=1; else f=fac(n-1)*n; ret

45、urn(f);fac(int n) int f; if(n0) printf(n%cn,getone,putone); void hanoi(int n,char one,char two,char three) if(n=1) move(one,three); else hanoi(n-1,one,three,two);move(one,three);hanoi(n-1,two,one,three); main() int m; printf(Input the number of disks:); scanf(%d,&m); printf(The steps to moving %3d d

46、isks:n,m); hanoi(m,A,B,C);ABC电电气气与与信信息息工工程程学学院院567.7数组作为函数参数数组作为函数参数电电气气与与信信息息工工程程学学院院57q 局部变量与全局变量局部变量与全局变量q局部变量局部变量-内部变量内部变量q定义:在定义:在函数内定义函数内定义,只在本函数内有效只在本函数内有效q说明:说明:main中定义的变量只在中定义的变量只在main中有效中有效不同函数中同名变量,占不同内存单元不同函数中同名变量,占不同内存单元形参属于局部变量形参属于局部变量可定义在复合语句中有效的变量可定义在复合语句中有效的变量float f1(int a) int b,c

47、; .char f2(int x,int y) int i,j; main() int m,n; .a,b,c有效x,y,i,j有效m,n有效不同函数中同名变量main() int a,b; a=3; b=4; printf(main:a=%d,b=%dn,a,b); sub(); printf(main:a=%d,b=%dn,a,b);sub() int a,b; a=6; b=7; printf(sub:a=%d,b=%dn,a,b);复合语句中变量#define N 5main() int i; int aN=1,2,3,4,5; for(i=0;iN/2;i+) int temp;te

48、mp=ai;ai=aN-i-1;aN-i-1=temp; for(i=0;iN;i+) printf(%d ,ai);运行结果:5 4 3 2 1复合语句中变量#define N 5main() int i; int aN=1,2,3,4,5; for(i=0;iN/2;i+) int temp;temp=ai;ai=aN-i-1;aN-i-1=temp; for(i=0;iN;i+) printf(%d ,ai);不同函数中同名变量main() int a,b; a=3; b=4; printf(main:a=%d,b=%dn,a,b); sub(); printf(main:a=%d,b=

49、%dn,a,b);sub() int a,b; a=6; b=7; printf(sub:a=%d,b=%dn,a,b);运行结果:main:a=3,b=4sub:a=6,b=7main:a=3,b=4q7.8局部变量和全局变量局部变量和全局变量电电气气与与信信息息工工程程学学院院58q全局变量-外部变量q定义:在函数外定义,可为本文件所有函数共用q有效范围:从定义变量的位置开始到本源文件结束,及有extern说明的其它源文件 应尽量少使用全局变量,因为:Y全局变量在程序全部执行过程中占用存储单元Y降低了函数的通用性、可靠性,可移植性Y降低程序清晰性,容易出错q若外部变量与局部变量同名,则外部

50、变量被屏蔽电电气气与与信信息息工工程程学学院院59float max,min;float average(float array, int n) int i; float sum=array0; max=min=array0; for(i=1;imax) max=arrayi; else if(arrayib?a:b; return(c);main() int a=8; printf(max=%d,max(a,b);例:全局变量与局部变量运行结果:max=8电电气气与与信信息息工工程程学学院院61int i;main() void prt(); for(i=0;i5;i+) prt();voi

51、d prt() for(i=0;i5;i+) printf(“%c”,*); printf(“n”);全局变量副作用运行结果:*电电气气与与信信息息工工程程学学院院62q变量的属性q数据类型:变量所持有的数据的性质(操作属性)q存储属性存储器类型:寄存器、静态存储区、动态存储区生存期:变量在某一时刻存在-静态变量与动态变量作用域:变量在某区域内有效-局部变量与全局变量q变量的存储类型auto -自动型register-寄存器型static -静态型extern -外部型q变量定义格式: 存储类型 数据类型 变量表;7.9变量的存储类别和生存期变量的存储类别和生存期q概述如: int sum;

52、auto int a,b,c; register int i; static float x,y;电电气气与与信信息息工工程程学学院院63q变量存储类型u局部变量默认为auto型uregister型变量个数受限,且不能为long, double, float型u局部static变量具有全局寿命和局部可见性u局部static变量具有可继承性uextern不是变量定义,可扩展外部变量作用域 定义 说明u次数: 只能1次 可说明多次u位置: 所有函数之外 函数内或函数外u分配内存: 分配内存,可初始化 不分配内存,不可初始化外部变量说明: extern 数据类型 变量表;外部变量定义与外部变量说明不同电电气气与与信信息息工工程程学学院院64int p=1,q=5;float f1(int a) int b,c; .int f3().char c1,c2;char f2(int x,int y) int i,j; main() int m,n; .c1,c2的作用范围p,q的作用范围extern char c1,c2;extern char c1,c2;c1,c2的作用范围扩展后c1,c2的作用范围

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论