实验函数参考程序
实验七 函数参考程序一、程序调试方法实验1.找出并改正以下源程序中错误,得出正确的运行结果。源程序如下:#include <stdio.h> /函数声明 int add(int a, int b);void main()int a,b;scanf("%d%d",&a,&b);printf("a+b=%d",add(a,b);void add(int a,b) /改为int add(int a, int b)return a+b;2.找出并改正以下源程序中错误,得出正确的运行结果,其中max函数的功能是得到数组中最大元素的值。源程序如下:#include <stdio.h>#define N 10; /去掉尾部分号float max(float a, int n) /尾部加上分号void main()float dataN;int i;for(i=0;i<N;i+)scanf("%f",datai); /改为scanf("%f", &datai);printf("max is=%f",max(dataN,N); / 改为printf("max is=%f",max(data, N); float max(float a, int n)int i,result; /改为 int i; float result; /增加result=a0;for(i=0;i<n;i+)if(ai > result)result = ai;return result;3.找出并改正以下源程序中错误,得出正确的运行结果,其中converse函数的功能是逆序输出n个字符。解题思路:已知字符串的长度,逆序输出字符串如果只有1个字符,直接输出该字符后结束否则:输出后面的所有字符之后,再输出该字符源程序如下:#include <stdio.h>void main() int i=5; void converse(int n); printf("Input 5 characters:"); converse(i); printf("n"); 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 <stdio.h>char isLow(char ch) if(ch >= 'a' && ch <= 'z') return ch - 32; else return ch;void main(void) char ch; printf("请输入一个字符:n"); scanf("%c",&ch); printf("%cn", isLow(ch);2、编写函数reverse(int number),它的功能是将number逆序输出,在main函数中输入一个整数,调用该函数得到逆序的数并输出。例如reverse(11233)的返回值为33211。#include <stdio.h>int reverse(int n) int rev=0,num; do num=n %10; rev = rev*10 + num; n=n/10; while(n); return rev;void main(void) int num,revnum; printf("请输入一个整数:n"); scanf("%d",&num); revnum = reverse(num); printf("逆序后整数为:%dn",revnum); 3、编写函数完成如下功能:将长整型数中数字为偶数的数依次取出,构成一个新数返回,例如,当s中的数为:87653142时,则返回的数为:8642。提示:依次取出长整型数的每一位数字,如果是偶数,则放入新数中。在main函数中输入一个长整型数,调用该函数得到新的数,并输出结果。#include "stdio.h"long func(long s);void main()long a;printf("请输入一个整数:");scanf("%ld",&a);printf("%ldn",func(a);long func(long n) long result=0;int num, weight=1 ; / weight表示数位的权值(即个、十、百,。)while ( n != 0 )num = n%10; /得到最低位if (num % 2=0) result= num * weight + result; /重新组织成新的数 weight=weight * 10;n/=10; /去掉最低位return (result);4、编写一个函数sort,实现数组元素的升序(或降序)排列。在main函数中输入数组元素,调用该函数进行排序,最后输出排序后的结果。#include <stdio.h>#define N 10void sort(float a, int n) /无返回值,在原数组上排序并带回 int i,j; float temp; for(i=0;i<n-1;i+) /*冒泡排序*/ for(j=i+1;j<n;j+) if(ai>aj) temp = ai; ai = aj; aj = temp; void main(void) float aN; int i; printf("请输入%d个数值:n",N); for(i=0;i<N;i+) scanf("%f",&ai); sort(a, N); printf("升序排序后的数组为:n"); for(i=0;i<N;i+) printf("%6.2f",ai); printf(”n”);5、编写函数求出二维整型数组中元素的最大值及其下标号。提示:这里至少需要返回二维数组元素的行,列两个值,而函数只能返回1个值(无法返回2个值),所以只能通过数组作为参数的方法将值带回来。在main函数中输入一个二维整型数组,调用该函数得到最大值所在的下标,并输出最大值及其下标号。#include <stdio.h>void max_value(int array4, int index) /没有返回值的函数,结果通过与index对应的数组带回int i,j,max;max=array00;for(i=0; i<3; i+)for(j=0; j<4; j+)if(max < arrayij) index0 = i;index1 = j;max = arrayij; void main()int a34=18,2,3,4,8,7,6,5,9,10,11,12;int maxindex2=0; /定义数组maxindex以保存最大值的行、列下标,因为函数无法返回2个值,只能通过数组带回来int i, j; max_value(a, maxindex);i=maxindex0;j=maxindex1;printf("Max=array%d%d=%dn",i,j,aij);6、编写函数,统计给定字符串中各个字母出现的次数,不区分大小写。在main函数中输入一个字符串,调用该函数进行计算,然后输出统计结果。提示:统计结果可以保存到一个数组中,如int count26,分别存储每个字母出现的次数,初值0,然后将数组作为函数参数将值带回来。#include "stdio.h"void fun(char s, int a) /将统计26个字母的结果存放在与数组a对应的实参中int i, j;for(i=0; si; i+)if(si >= 'A' && si <= 'Z')j = si-'A' /得到该字母在26个字母中的序号else if(si >= 'a' && si <= 'z')j = si-'a'aj+; /对应字母的个数加1 int main(void) char str80; int count26=0, i; /count数组26个元素分别存储每个字母出现的次数,初值0 printf("请输入一串字符以回车键结束:n"); gets(str); fun(str, count); /输出统计结果 for(i=0; i<26;