第7章用函数实现模块化程序设计Convertor.doc
第 7 章 用函数实现模块化程序设计7.1 为什么要用函数7.2 怎样定义函数7.3 调用函数7.4 对被调用函数的声明和函数原型7.5 函数的嵌套调用7.6 函数的递归调用7.7 数组作为函数参数7.8 局部变量和全局变量7.9 变量的存储方式和生存期7.10 关于变量的声明和定义7.11 内部函数和外部函数7.1 为什么要用函数问题:如果程序的功能比较多,规模比较大,把所有代码都写在 main 函数中,就会使主函数变得庞杂、头绪不清,阅读和维护变得困难有时程序中要多次实现某一功能,就需要多次重复编写实现此功能的程序代码,这使程序冗长,不精炼7.1 为什么要用函数解决的方法:用模块化程序设计的思路采用“组装”的办法简化程序设计的过程事先编好一批实现各种不同功能的函数把它们保存在函数库中,需要时直接用7.1 为什么要用函数解决的方法:用模块化程序设计的思路函数就是功能每一个函数用来实现一个特定的功能函数的名字应反映其代表的功能7.1 为什么要用函数在设计一个较大的程序时,往往把它分为若干个程序模块,每一个模块包括一个或多个函数,每个函数实现一个特定的功能程序可由一个主函数和若干个其他函数构成主函数调用其他函数,其他函数也可以互相调用同一个函数可以被一个或多个函数调用任意多次7.1 为什么要用函数mainabcfghdeie7.1 为什么要用函数可以使用库函数可以使用自己编写的函数在程序设计中要善于利用函数,可以减少重复编写程序段的工作量,同时可以方便地实现模块化的程序设计7.1 为什么要用函数例 7.1 输出以下的结果,用函数调用实现。*How do you do!*7.1 为什么要用函数解题思路:在输出的文字上下分别有一行“*”号,显然不必重复写这段代码,用一个函数 print_star 来实现输出一行“*”号的功能。再写一个 print_message 函数来输出中间一行文字信息用主函数分别调用这两个函数#include int main()void print_star();void print_message();print_star();print_message();print_star();return 0;void print_star()printf(“*n”);void print_message()printf(“How do you do!n”);输出 16 个*输出一行文字#include int main()void print_star();void print_message();print_star();print_message();print_star();return 0;void print_star()printf(“*n”);void print_message()printf(“How do you do!n”);声明函数定义函数#include int main()void print_star();void print_message();print_star();print_message();print_star();return 0;void print_star()printf(“*n”);void print_message()printf(“How do you do!n”);说明:(1)一个程序由一个或多个程序模块组成,每一个程序模块作为一个源程序文件。对较大的程序,一般不希望把所有内容全放在一个文件中,而是将它们分别放在若干个源文件中,由若干个源程序文件组成一个 C 程序。这样便于分别编写、分别编译,提高调试效率。一个源程序文件可以为多个 C 程序共用。说明:(2)一个源程序文件由一个或多个函数以及其他有关内容(如预处理指令、数据声明与定义等)组成。一个源程序文件是一个编译单位,在程序编译时是以源程序文件为单位进行编译的,而不是以函数为单位进行编译的。说明:(3)程序的执行是从 main 函数开始的,如果在 main 函数中调用其他函数,在调用后流程返回到 main 函数,在 main 函数中结束整个程序的运行。说明:(4)所有函数都是平行的,即在定义函数时是分别进行的,是互相独立的。一个函数并不从属于另一个函数,即函数不能嵌套定义。函数间可以互相调用,但不能调用 main 函数。main 函数是被操作系统调用的。说明:(5)从用户使用的角度看,函数有两种。库函数,它是由系统提供的,用户不必自己定义而直接使用它们。应该说明,不同的 C 语言编译系统提供的库函数的数量和功能会有一些不同,当然许多基本的函数是共同的。用户自己定义的函数。它是用以解决用户专门需要的函数。说明:(6)从函数的形式看,函数分两类。无参函数。无参函数一般用来执行指定的一组操作。无参函数可以带回或不带回函数值,但一般以不带回函数值的居多。有参函数。在调用函数时,主调函数在调用被调用函数时,通过参数向被调用函数传递数据,一般情况下,执行被调用函数时会得到一个函数值,供主调函数使用。7.2 怎样定义函数7.2.1 为什么要定义函数7.2.2 定义函数的方法7.2.1 为什么要定义函数C 语言要求,在程序中用到的所有函数,必须“先定义,后使用”指定函数名字、函数返回值类型、函数实现的功能以及参数的个数与类型,将这些信息通知编译系统。7.2.1 为什么要定义函数指定函数的名字,以便以后按名调用指定函数类型,即函数返回值的类型指定函数参数的名字和类型,以便在调用函数时向它们传递数据指定函数的功能。这是最重要的,这是在函数体中解决的7.2.1 为什么要定义函数对于库函数,程序设计者只需用#include 指令把有关的头文件包含到本文件模块中即可程序设计者需要在程序中自己定义想用的而库函数并没有提供的函数7.2.2 定义函数的方法1.定义无参函数定义无参函数的一般形式为:类型名函数名(void)函数体类型名函数名()函数体包括声明部分和语句部分包括声明部分和语句部分7.2.2 定义函数的方法1.定义无参函数定义无参函数的一般形式为:类型名函数名(void)函数体类型名函数名()函数体指定函数值的类型指定函数值的类型7.2.2 定义函数的方法2.定义有参函数定义有参函数的一般形式为:类型名 函数名(形式参数表列)函数体7.2.2 定义函数的方法3.定义空函数定义空函数的一般形式为:类型名 函数名()先用空函数占一个位置,以后逐步扩充好处:程序结构清楚,可读性好,以后扩充新功能方便,对程序结构影响不大7.3 调用函数7.3.1 函数调用的形式7.3.2 函数调用时的数据传递7.3.3 函数调用的过程7.3.4 函数的返回值7.3.1 函数调用的形式函数调用的一般形式为:函数名(实参表列)如果是调用无参函数,则“实参表列”可以没有,但括号不能省略如果实参表列包含多个实参,则各参数间用逗号隔开7.3.1 函数调用的形式按函数调用在程序中出现的形式和位置来分,可以有以下 3 种函数调用方式:.函数调用语句把函数调用单独作为一个语句如 printf_star();这时不要求函数带回值,只要求函数完成一定的操作7.3.1 函数调用的形式按函数调用在程序中出现的形式和位置来分,可以有以下 3 种函数调用方式:.函数表达式函数调用出现在另一个表达式中如 c=max(a,b);这时要求函数带回一个确定的值以参加表达式的运算7.3.1 函数调用的形式按函数调用在程序中出现的形式和位置来分,可以有以下 3 种函数调用方式:.函数参数函数调用作为另一函数调用时的实参如 mmax(a,max(b,c);其中 max(b,c)是一次函数调用,它的值作为 max 另一次调用的实参7.3.2 函数调用时的数据传递1.形式参数和实际参数在调用有参函数时,主调函数和被调用函数之间有数据传递关系定义函数时函数名后面的变量名称为“形式参数”(简称“形参”)主调函数中调用一个函数时,函数名后面参数称为“实际参数”(简称“实参”)实际参数可以是常量、变量或表达式7.3.2 函数调用时的数据传递2.实参和形参间的数据传递在调用函数过程中,系统会把实参的值传递给被调用函数的形参或者说,形参从实参得到一个值该值在函数调用期间有效,可以参加被调函数中的运算7.3.2 函数调用时的数据传递例 7.2 输入两个整数,要求输出其中值较大者。要求用函数来找到大数。解题思路:(1)函数名应是见名知意,今定名为 max(2)由于给定的两个数是整数,返回主调函数的值(即较大数)应该是整型(3)max 函数应当有两个参数,以便从主函数接收两个整数,因此参数的类型应当是整型7.3.2 函数调用时的数据传递先编写 max 函数:int max(int x,int y)int z;z=xy?x:y;return(z);7.3.2 函数调用时的数据传递在 max 函数上面,再编写主函数#include int main()int max(int x,int y);int a,b,c;printf(“two integer numbers:);scanf(“%d,%d”,&a,&b);c=max(a,b);printf(“max is%dn”,c);实参可以是常量、变量或表达式7.3.2 函数调用时的数据传递c=max(a,b);(main 函数)int max(int x,int y)(max 函数)int z;z=xy?x:y;return(z);7.3.3 函数调用的过程在定义函数中指定的形参,在未出现函数调用时,它们并不占内存中的存储单元。在发生函数调用时,函数 max 的形参被临时分配内存单元。2a3bxy23实参形参7.3.3 函数调用的过程调用结束,形参单元被释放实参单元仍保留并维持原值,没有改变如果在执行一个被调用函数时,形参的值发生改变,不会改变主调函数的实参的值2a3bxy23实参形参7.3.4.函数的返回值通常,希望通过函数调用使主调函数能得到一个确定的值,这就是函数值(函数的返回值)函数的返回值是通过函数中的 return 语句获得的。一个函数中可以有一个以上的 return 语句,执行到哪一个 return 语句,哪一个就起作用return 语句后面的括号可以不要7.3.4.函数的返回值通常,希望通过函数调用使主调函数能得到一个确定的值,这就是函数值(函数的返回值)(2)函数值的类型。应当在定义函数时指定函数值的类型7.3.4.函数的返回值通常,希望通过函数调用使主调函数能得到一个确定的值,这就是函数值(函数的返回值)(3)在定义函数时指定的函数类型一般应该和 return 语句中的表达式类型一致如果函数值的类型和 return 语句中表达式的值不一致,则以函数类型为准7.3.4.函数的返回值例 7.3 将例 7.2 稍作改动,将在 max 函数中定义的变量 z 改为 float 型。函数返回值的类型与指定的函数类型不同,分析其处理方法。解题思路:如果函数返回值的类型与指定的函数类型不同,按照赋值规则处理。#include int main()int max(float x,float y);float a,b;int c;scanf(%f,%f,&a,&b);c=max(a,b);printf(max is%dn,c);return 0;int max(float x,float y)float z;z=xy?x:y;return(z);1.52.62.62变为 27.4 对被调用函数的声明和函数原型在一个函数中调用另一个函数需要具备如下条件:(1)被调用函数必须是已经定义的函数(是库函数或用户自己定义的函数)(2)如果使用库函数,应该在本文件开头加相应的#include 指令(3)如果使用自己定义的函数,而该函数的位置在调用它的函数后面,应该声明7.4 对被调用函数的声明和函数原型例 7.4 输入两个实数,用一个函数求出它们之和。解题思路:用 add 函数实现。首先要定义 add 函数,它为 float 型,它应有两个参数,也应为 float 型。特别要注意的是:要对 add 函数进行声明。7.4 对被调用函数的声明和函数原型分别编写 add 函数和 main 函数,它们组成一个源程序文件main 函数的位置在 add 函数之前在 main 函数中对 add 函数进行声明#include int main()float add(float x,float y);float a,b,c;printf(Please enter a and b:);scanf(%f,%f,&a,&b);c=add(a,b);printf(sum is%fn,c);return 0;float add(float x,float y)float z;z=x+y;return(z);求两个实数之和,函数值也是实型对 add 函数声明#include int main()float add(float x,float y);float a,b,c;printf(Please enter a and b:);scanf(%f,%f,&a,&b);c=add(a,b);printf(sum is%fn,c);return 0;float add(float x,float y)float z;z=x+y;return(z);只差一个分号#include int main()float add(float x,float y);float a,b,c;printf(Please enter a and b:);scanf(%f,%f,&a,&b);c=add(a,b);printf(sum is%fn,c);return 0;float add(float x,float y)float z;z=x+y;return(z);定义 add 函数调用 add 函数函数原型的一般形式有两种:如float add(float x,float y);float add(float,float);原型说明可以放在文件的开头,这时所有函数都可以使用此函数7.5 函数的嵌套调用语言的函数定义是互相平行、独立的即函数不能嵌套定义但可以嵌套调用函数即调用一个函数的过程中,又可以调用另一个函数7.5 函数的嵌套调用main 函数调用 a 函数结束a 函数调用 b 函数b 函数7.5 函数的嵌套调用例 7.5 输入 4 个整数,找出其中最大的数。用函数的嵌套调用来处理。解题思路:main 中调用 max4 函数,找 4 个数中最大者max4 中再调用 max2,找两个数中的大者max4 中多次调用 max2,可找 4 个数中的大者,然后把它作为函数值返回 main 函数main 函数中输出结果#include int main()int max4(int a,int b,int c,int d);int a,b,c,d,max;printf(“4 interger numbers:);scanf(%d%d%d%d,&a,&b,&c,&d);max=max4(a,b,c,d);printf(max=%d n,max);return 0;主函数对 max4 函数声明#include int main()int max4(int a,int b,int c,int d);int a,b,c,d,max;printf(“4 interger numbers:);scanf(%d%d%d%d,&a,&b,&c,&d);max=max4(a,b,c,d);printf(max=%d n,max);return 0;主函数输入 4 个整数#include int main()int max4(int a,int b,int c,int d);int a,b,c,d,max;printf(“4 interger numbers:);scanf(%d%d%d%d,&a,&b,&c,&d);max=max4(a,b,c,d);printf(max=%d n,max);return 0;主函数调用后肯定是 4 个数中最大者输出最大者int max4(int a,int b,int c,int d)int max2(int a,int b);int m;m=max2(a,b);m=max2(m,c);m=max2(m,d);return(m);max4 函数对 max2 函数声明int max4(int a,int b,int c,int d)int max2(int a,int b);int m;m=max2(a,b);m=max2(m,c);m=max2(m,d);return(m);max4 函数a,b 中较大者a,b,c 中较大者a,b,c,d 中最大者int max4(int a,int b,int c,int d)int max2(int a,int b);int m;m=max2(a,b);m=max2(m,c);m=max2(m,d);return(m);max4 函数int max2(int a,int b)if(a=b)return a;elsereturn b;max2 函数找 a,b 中较大者int max4(int a,int b,int c,int d)int max2(int a,int b);int m;m=max2(a,b);m=max2(m,c);m=max2(m,d);return(m);max4 函数int max2(int a,int b)if(a=b)return a;elsereturn b;max2 函数return(ab?a:b);int max4(int a,int b,int c,int d)int max2(int a,int b);int m;m=max2(a,b);m=max2(m,c);m=max2(m,d);return(m);max4 函数int max2(int a,int b)return(ab?a:b);int max4(int a,int b,int c,int d)int max2(int a,int b);int m;m=max2(a,b);m=max2(m,c);m=max2(m,d);return(m);max4 函数m=max2(max2(a,b),c);int max2(int a,int b)return(ab?a:b);int max4(int a,int b,int c,int d)int max2(int a,int b);int m;m=max2(a,b);m=max2(m,c);m=max2(m,d);return(m);max4 函数m=max2(max2(max2(a,b),c),d);int max2(int a,int b)return(ab?a:b);int max4(int a,int b,int c,int d)int max2(int a,int b);int m;m=max2(a,b);m=max2(m,c);m=max2(m,d);return(m);max4 函数ruturn max2(max2(max2(a,b),c),d);int max2(int a,int b)return(ab?a:b);int max4(int a,int b,int c,int d)int max2(int a,int b);ruturn max2(max2(max2(a,b),c),d);int max2(int a,int b)return(ab?a:b);#include int main()max=max4(a,b,c,d);7.6 函数的递归调用在调用一个函数的过程中又出现直接或间接地调用该函数本身,称为函数的递归调用。语言的特点之一就在于允许函数的递归调用。f2 函数调用 f1 函数7.6 函数的递归调用int f(int x)int y,z;z=f(y);return(2*z);f 函数调用 f 函数f1 函数调用 f2 函数应使用 if 语句控制结束调用直接调用本函数间接调用本函数7.6 函数的递归调用例 7.6 有 5 个学生坐在一起问第 5 个学生多少岁?他说比第 4 个学生大 2 岁问第 4 个学生岁数,他说比第 3 个学生大 2 岁问第 3 个学生,又说比第 2 个学生大 2 岁问第 2 个学生,说比第 1 个学生大 2 岁最后问第 1 个学生,他说是 10 岁请问第 5 个学生多大7.6 函数的递归调用解题思路:要求第个年龄,就必须先知道第个年龄要求第个年龄必须先知道第个年龄第个年龄又取决于第个年龄第个年龄取决于第个年龄每个学生年龄都比其前个学生的年龄大7.6 函数的递归调用解题思路:age(5)=age(4)+2age(4)=age(3)+2age(3)=age(2)+2age(2)=age(1)+2age(1)=10age(5)=age(4)+2age(4)=age(3)+2age(3)=age(2)+2age(2)=age(1)+2age(1)=10age(2)=12age(3)=14age(4)=16age(5)=18回溯阶段递推阶段age(5)=age(4)+2age(4)=age(3)+2age(3)=age(2)+2age(2)=age(1)+2age(1)=10age(2)=12age(3)=14age(4)=16age(5)=18回溯阶段递推阶段结束递归的条件#include int main()int age(int n);printf(NO.5,age:%dn,age(5);return 0;int age(int n)int c;if(n=1)c=10;elsec=age(n-1)+2;return(c);age(5)输出 age(5)mainc=age(4)+2age 函数n=5c=age(3)+2age 函数n=4c=age(1)+2age 函数n=2c=age(2)+2age 函数n=3c=10age 函数n=1age(1)=10age(2)=12age(3)=14age(4)=16age(5)=1818例 7.7 用递归方法求!。解题思路:求!可以用递推方法:即从开始,乘,再乘一直乘到。递推法的特点是从一个已知的事实(如 1!=1)出发,按一定规律推出下一个事实(如 2!=1!*2),再从这个新的已知的事实出发,再向下推出一个新的事实(3!=3*2!)。n!=n*(n-1)!。例 7.7 用递归方法求!。解题思路:求!也可以用递归方法,即!等于!,而!,!可用下面的递归公式表示:#include int main()int fac(int n);int n;int y;printf(input an integer number:);scanf(%d,&n);y=fac(n);printf(%d!=%dn,n,y);return 0;int fac(int n)int f;if(n0)printf(n0,data error!);else if(n=0|n=1)f=1;elsef=fac(n-1)*n;return(f);注意溢出fac(5)输出 fac(5)mainf=fac(4)5fac 函数n=5f=fac(3)4fac 函数n=4f=fac(1)2fac 函数n=2f=fac(2)3fac 函数n=3f=1fac 函数n=1fac(1)=1fac(2)=2fac(3)=6fac(4)=24fac(5)=120120例 7.8 Hanoi(汉诺)塔问题。古代有一个梵塔,塔内有 3 个座 A、B、C,开始时座上有64 个盘子,盘子大小不等,大的在下,小的在上。有一个老和尚想把这 64 个盘子从座移到座,但规定每次只允许移动一个盘,且在移动过程中在 3 个座上都始终保持大盘在下,小盘在上。在移动过程中可以利用 B 座。要求编程序输出移动一盘子的步骤。解题思路:要把 64 个盘子从 A 座移动到 C 座,需要移动大约 264 次盘子。一般人是不可能直接确定移动盘子的每一个具体步骤的老和尚会这样想:假如有另外一个和尚能有办法将上面 63 个盘子从一个座移到另一座。那么,问题就解决了。此时老和尚只需这样做:解题思路:(1)命令第 2 个和尚将 63 个盘子从 A 座移到 B 座(2)自己将 1 个盘子(最底下的、最大的盘子)从 A 座移到 C 座(3)再命令第 2 个和尚将 63 个盘子从 B 座移到 C 座ABC将 63 个从 A 到 B第 1 个和尚的做法ABC将 63 个从 A 到 B第 1 个和尚的做法ABC将 1 个从 A 到 C第 1 个和尚的做法ABC将 1 个从 A 到 C第 1 个和尚的做法ABC将 63 个从 B 到 C第 1 个和尚的做法ABC将 63 个从 B 到 C第 1 个和尚的做法ABC将 62 个从 A 到 C第 2 个和尚的做法ABC将 62 个从 A 到 C第 2 个和尚的做法ABC将 1 个从 A 到 B第 2 个和尚的做法ABC将 1 个从 A 到 B第 2 个和尚的做法ABC将 62 个从 C 到 B第 2 个和尚的做法ABC将 62 个从 C 到 B第 2 个和尚的做法第 3 个和尚的做法第 4 个和尚的做法第 5 个和尚的做法第 6 个和尚的做法第 7 个和尚的做法第 63 个和尚的做法第 64 个和尚仅做:将 1 个从 A 移到 CABC将 3 个盘子从 A 移到 C 的全过程将 2 个盘子从 A 移到 BABC将 3 个盘子从 A 移到 C 的全过程将 2 个盘子从 A 移到 BABC将 3 个盘子从 A 移到 C 的全过程将 1 个盘子从 A 移到 CABC将 3 个盘子从 A 移到 C 的全过程将 1 个盘子从 A 移到 CABC将 3 个盘子从 A 移到 C 的全过程将 2 个盘子从 B 移到 CABC将 3 个盘子从 A 移到 C 的全过程将 2 个盘子从 B 移到 CABC将 2 个盘子从 A 移到 B 的过程将 1 个盘子从 A 移到 CABC将 2 个盘子从 A 移到 B 的过程将 1 个盘子从 A 移到 CABC将 2 个盘子从 A 移到 B 的过程将 1 个盘子从 A 移到 BABC将 2 个盘子从 A 移到 B 的过程将 1 个盘子从 A 移到 BABC将 2 个盘子从 A 移到 B 的过程将 1 个盘子从 C 移到 BABC将 2 个盘子从 A 移到 B 的过程将 1 个盘子从 C 移到 BABC将 2 个盘子从 B 移到 C 的过程ABC将 2 个盘子从 B 移到 C 的过程ABC将 2 个盘子从 B 移到 C 的过程ABC将 2 个盘子从 B 移到 C 的过程由上面的分析可知:将 n 个盘子从 A 座移到 C 座可以分解为以下 3 个步骤:(1)将 A 上 n-1 个盘借助 C 座先移到 B 座上(2)把 A 座上剩下的一个盘移到 C 座上(3)将 n-1 个盘从 B 座借助于座移到 C 座上可以将第(1)步和第(3)步表示为:将“one”座上 n-1 个盘移到“two”座(借助“three”座)。在第(1)步和第(3)步中,one、two、three 和 A、B、C 的对应关系不同。对第(1)步,对应关系是 one 对应 A,two 对应 B,three 对应 C。对第(3)步,对应关系是 one 对应 B,two 对应 C,three 对应 A。把上面 3 个步骤分成两类操作:(1)将 n-1 个盘从一个座移到另一个座上(n1)。这就是大和尚让小和尚做的工作,它是一个递归的过程,即和尚将任务层层下放,直到第 64 个和尚为止。(2)将 1 个盘子从一个座上移到另一座上。这是大和尚自己做的工作。编写程序。用 hanoi 函数实现第 1 类操作(即模拟小和尚的任务)用 move 函数实现第 2 类操作(模拟大和尚自己移盘)函数调用 hanoi(n,one,two.three)表示将 n 个盘子从“one”座移到“three”座的过程(借助“two”座)函数调用 move(x,y)表示将 1 个盘子从 x 座移到 y 座的过程。x 和 y 是代表 A、B、C 座之一,根据每次不同情况分别取 A、B、C 代入#include int main()void hanoi(int n,char one,char two,char three);int m;printf(“the number of diskes:);scanf(%d,&m);printf(move%d diskes:n,m);hanoi(m,A,B,C);void hanoi(int n,char one,char two,char three)void move(char x,char y);if(n=1)move(one,three);elsehanoi(n-1,one,three,two);move(one,three);hanoi(n-1,two,one,three);void move(char x,char y)printf(%c-%cn,x,y);7.7 数组作为函数参数7.7.1 数组元素作函数实参7.7.2 数组名作函数参数7.7.3 多维数组名作函数参数7.7.1 数组元素作函数实参例 7.9 输入 10 个数,要求输出其中值最大的元素和该数是第几个数。7.7.1 数组元素作函数实参解题思路:定义数组 a,用来存放 10 个数设计函数 max,用来求两个数中的大者在主函数中定义变量 m,初值为 a0,每次调用 max 函数后的返回值存放在 m 中用“打擂台”算法,依次将数组元素 a1到 a9与 m 比较,最后得到的 m 值就是 10 个数中的最大者#include int main()int max(int x,int y);int a10,m,n,i;printf(“10 integer numbers:n);for(i=0;i10;i+)scanf(%d,&ai);printf(n);for(i=1,m=a0,n=0;im)m=max(m,ai);n=i;printf(“largest number is%dn,m);printf(“%dth number.n“,n+1);int max(int x,int y)return(xy?x:y);7.7.2 数组名作函数参数除了可以用数组元素作为函数参数外,还可以用数组名作函数参数(包括实参和形参)用数组元素作实参时,向形参变量传递的是数组元素的值用数组名作函数实参时,向形参 传递的是数组首元素的地址7.7.2 数组名作函数参数例 7.10 有一个一维数组 score,内放 10 个学生成绩,求平均成绩。解题思路:用函数 average 求平均成绩,用数组名作为函数实参,形参也用数组名在 average 函数中引用各数组元素,求平均成绩并返回 main 函数#include int main()float average(float array10);float score10,aver;int i;printf(input 10 scores:n);for(i=0;i10;i+)scanf(%f,&scorei);printf(n);aver=average(score);printf(%5.2fn,aver);return 0;定义实参数组float average(float array10)int i;float aver,sum=array0;for(i=1;i10;i+)sum=sum+arrayi;aver=sum/10;return(aver);定义形参数组相当于 score0相当于 scorei例 7.11 有两个班级,分别有 35 名和 30 名学生,调用一个 average 函数,分别求这两个班的学生的平均成绩。解题思路:需要解决怎样用同一个函数求两个不同长度的数组的平均值的问题定义 average 函数时不指定数组的长度,在形参表中增加一个整型变量 i从主函数把数组实际长度从实参传递给形参 i这个 i 用来在 average 函数中控制循环的次数为简化,设两个班的学生数分别为 5 和 10#include int main()float average(float array,int n);float score15=98.5,97,91.5,60,55;float score210=67.5,89.5,99,69.5,77,89.5,76.5,54,60,99.5;printf(“%6.2fn”,average(score1,5);printf(“%6.2fn”,average(score2,10);return 0;float average(float array,int n)int i;float aver,sum=array0;for(i=1;in;i+)sum=sum+arrayi;aver=sum/n;return(aver);调用形式为 average(score1,5)时相当于 score10相当于 score1i相当于 5float average(float array,int n)int i;float aver,sum=array0;for(i=1;in;i+)sum=sum+arrayi;aver=sum/n;return(aver);调用形式为 average(score2,10)时相当于 score20相当于 score2i相当于 10例 7.12 用选择法对数组中 10 个整数按由小到大排序。解题思路:所谓选择法就是先将 10 个数中最小的数与 a0对换;再将 a1到 a9中最小的数与 a1对换每比较一轮,找出一个未经排序的数中最小的一个共比较 9 轮a0a1a2a3a43619416394136941349613469小到大排序#include int main()void sort(int array,int n);int a10,i;printf(enter array:n);for(i=0;i10;i+)scanf(%d,&ai);sort(a,10);printf(The sorted array:n);for(i=0;i10;i+)printf(%d,ai);printf(n);return 0;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;t=arrayk;arrayk=arrayi;arrayi=t;在 sortisort9中,最小数与 sorti对换7.7.3 多维数组名作函数参数例 7.13 有一个的矩阵,求所有元素中的最大值。解题思路:先使变量 max 的初值等于矩阵中第一个元素的值,然后将矩阵中各个元素的值与 max 相比,每次比较后都把“大者”存放在 max 中,全部元素比较完后,max 的值就是所有元素的最大值。#include int main()int max_value(int array4);int a34=1,3,5,7,2,4,6,8,15,17,34,12;printf(“Max value is%dn”,max_value(a);return 0;可以省略不能省略要与形参数组第二维大小相同int max_value(int array4)int i,j,max;max=array00;for(i=0;i3;i+)for(j=0;jmax)max=arrayij;return(max);要与实参数组第二维大小相同7.8 局部变量和全局变量7.8.1 局部变量7.8.2 全局变量7.8.1 局部变量定义变量可能有三种情况:在函数的开头定义在函数内的复合语句内定义在函数的外部定义7.8.1 局部变量在一个函数内部定义的变量只在本函数范围内有效在复合语句内定义的变量只在本复合语句范围内有效在函数内部或复合语句内部定义的变量称为“局部变量”fl