实验七 函数——参考程序
一、程序调试方法实验
1.找出并改正以下源程序中错误,得出正确的运行结果。 源程序如下:
#include
//函数声明 int add(int a, int b); void main() { int a,b; scanf(\ printf(\ }
void add(int a,b) //改为int add(int a, int b) { return a+b; }
2.找出并改正以下源程序中错误,得出正确的运行结果,其中max函数的功能是得到数组中最大元素的值。 源程序如下:
#include
#define N 10; //去掉尾部分号 float max(float a[], int n) //尾部加上分号 void main() { float data[N]; int i; for(i=0;i float max(float a[], int n) { int i,result; //改为 int i; float result; //增加result=a[0]; for(i=0;i } return result; 3.找出并改正以下源程序中错误,得出正确的运行结果,其中converse函数的功能是逆序输出 n个字符。 解题思路:已知字符串的长度,逆序输出字符串 如果只有1个字符,直接输出该字符后结束 否则:输出后面的所有字符之后,再输出该字符 源程序如下: #include void main() { int i=5; void converse(int n); printf(\ converse(i); printf(\ } void converse(n); //改为void converse(int n) 并去掉分号 { char next; if(n>=1) //改为 if(n= =1) { next=getchar(); putchar(next); } else { next=getchar(); converse(n-1); putchar(next); } } 四、编写程序 1、编写一个函数,其功能是判断形式参数是否为小写字母,若是,返回其对应的大写字母,否则返回原字符。然后在main函数中输入一个字符,调用该函数得到其大写字母并输出 #include if(ch >= 'a' && ch <= 'z') return ch - 32; else return ch; } void main(void) { char ch; printf(\请输入一个字符:\\n\ scanf(\ printf(\} 2、编写函数reverse(int number),它的功能是将number逆序输出,在main函数中输入一个整数,调用该函数得到逆序的数并输出。例如reverse(11233)的返回值为33211。 #include int rev=0,num; do { num=n ; rev = rev*10 + num; n=n/10; }while(n); return rev; } void main(void) { int num,revnum; printf(\请输入一个整数:\\n\ scanf(\ revnum = reverse(num); printf(\逆序后整数为:%d\\n\} 3、编写函数完成如下功能:将长整型数中数字为偶数的数依次取出,构成一个新数返回,例如,当s中的数为:87653142时,则返回的数为:8642。 提示:依次取出长整型数的每一位数字,如果是偶数,则放入新数中。在main函数中输入一个长整型数,调用该函数得到新的数,并输出结果。 #include \long func(long s); void main() { long a; printf(\请输入一个整数:\ scanf(\ printf(\} long func(long n) { long result=0; int num, weight=1 ; // weight表示数位的权值(即个、十、百,。。。。) while ( n != 0 ) { num = n; //得到最低位 if (num % 2==0) { result= num * weight + result; //重新组织成新的数 weight=weight * 10; } n/=10; //去掉最低位 } return (result); } 4、编写一个函数sort,实现数组元素的升序(或降序)排列。在main函数中输入数组元素,调用该函数进行排序,最后输出排序后的结果。 #include void sort(float a[], int n) //无返回值,在原数组上排序并带回 { int i,j; float temp; for(i=0;i temp = a[i]; a[i] = a[j]; a[j] = temp; } } void main(void) { float a[N]; int i; printf(\请输入%d个数值:\\n\ for(i=0;i scanf(\ sort(a, N); printf(\升序排序后的数组为:\\n\ for(i=0;i printf(\ printf(”\\n”); } 5、编写函数求出二维整型数组中元素的最大值及其下标号。 提示:这里至少需要返回二维数组元素的行,列两个值,而函数只能返回1个值(无法返回2个值),所以只能通过数组作为参数的方法将值带回来。在main函数中输入一个二维整型数组,调用该函数得到最大值所在的下标,并输出最大值及其下标号。 #include void max_value(int array[][4], int index[]) //没有返回值的函数,结果通过与index对应的数组带回 { int i,j,max; max=array[0][0]; for(i=0; i<3; i++) for(j=0; j<4; j++) if(max < array[i][j]) { index[0] = i; index[1] = j; max = array[i][j]; } } void main() { int a[3][4]={{18,2,3,4}, {8,7,6,5},