第1套
1.程序填空题
给定程序中,函数fun的功能是:统计整型变量m中各数字出现的次数,并存放到数组a中,其中,a[0]存放0出现的次数,a[1]存放1出现的次数,……,a[9]存放9出现的次数。
例如,若m为14579233,则输出结果为:0,1,1,2,1,1,0,1,0,1。
请在下划线处填入正确的内容并将下划线删除,使程序得出正确的结果。
注意:不得增行或删行,也不得更改程序的结构!
#include <stdio.h> void fun( int m, int a[10]) { int i; for (i=0; i<10; i++) /**********found**********/ __1__ = 0; while (m > 0) { /**********found**********/ i = ___2___; a[i]++; /**********found**********/ m = ___3___; } } int main() { int m, a[10],i; printf("请输入一个整数 : "); scanf("%d", &m); fun(m, a); for (i=0; i<10; i++) printf("%d,",a[i]); printf("n"); return 0; }
2.程序修改题
给定程序中,函数fun的功能是:求矩阵(二维数组)a[N][N]中每行的最小值,结果存放到数组b中。
例如,程序运行后,输出结果应为1,5,9,13。
请改正函数fun中指定部位的错误,使它能得出正确的结果。
注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。
#include <stdio.h> #define N 4 void fun(int a[][N], int b[]) { int i, j; for (i=0; i<N; i++) { /**********found**********/ b[i] = a[0][0]; /**********found**********/ for (j=1; j<N-1; j++) /**********found**********/ if ( b[i] < a[i][j] ) b[i] = a[i][j]; } } int main() { int a[N][N]={{1,4,3,2},{8,6,5,7},{11,10,12,9}, {13,16,14,15}},b[N]; int i; fun(a,b); for (i=0; i<N; i++) printf("%d,", b[i]); printf("n"); return 0; }
3.程序设计题
编写函数fun,其功能是:将一组得分中,去掉一个最高分和一个最低分,然后求平均值,并通过函数返回。函数形参a指向存放得分的数组,n存放得分个数(n>2)。
例如,若输入9.9 8.5 7.6 8.5 9.3 9.5 8.9 7.8 8.6 8.4十个得分,则输出结果为:8.687500。
注意:请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
#include <stdio.h> void NONO(void); double fun(double a[] , int n) { } int main() { double b[10], r; int i; printf("输入10个分数放入b数组中 : "); for (i=0; i<10; i++) scanf("%lf",&b[i]); printf("输入的10个分数是 : "); for (i=0; i<10; i++) printf("%4.1f ",b[i]); printf("n"); r = fun(b, 10); printf("去掉最高分和最低分后的平均分 : %fn", r ); NONO(); return 0; } void NONO() {/* 本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。 */ FILE *fp, *wf ; int i, j ; double b[10], r ; fp = fopen("in.dat","r"); wf = fopen("out.dat","w"); for(i = 0 ; i < 10 ; i++) { for(j = 0 ; j < 10 ; j++) fscanf(fp, "%lf ", &b[j]); r = fun(b, 10) ; fprintf(wf, "%fn", r); } fclose(fp); fclose(wf); }
1.(1)a[i] (2)m%10 (3)m/10 2. b[i] = a[i][0]; for (j=1; j<N; j++) if ( b[i] > a[i][j] ) 3. double fun(double a[] , int n) { double max,min,s; s=max=min=a[0]; int i; for (i=1;i<n;i++) { if (max<a[i]) max=a[i]; if (min>a[i]) min=a[i]; s+=a[i]; } return (s-max-min)/(n-2); }
第2套
1.程序填空题
围绕山顶一圈有N个山洞,编号为0、1、2、…、N-1,有一只狐狸和一只兔子在洞中居住。狐狸总想找到兔子并吃掉它,它的寻找方法是先到第一个洞(即编号为0的洞)中找;再隔1个洞,到编号为2的洞中找;再隔2个洞,到编号为5的洞中找;再隔3个洞,到编号为9的洞中找;……。若狐狸找一圈,请为兔子指出所有不安全的洞号。若形参n的值为30时,不安全的洞号是0、2、5、9、14、20、27。
请在下划线处填入正确的内容并将下划线删除,使程序得出正确的结果。
注意:不得增行或删行,也不得更改程序的结构!
#include <stdio.h> #define N 100 void fun(int *a ,int n) { int i, t; for( i=0; i<n; i++ ) /**********found**********/ a[i]=___1___; i=0; /**********found**********/ ___2___=1; while( i<n ) { a[i]= 1; t++; /**********found**********/ i=___3___; } } int main() { int a[N], i, n=30; fun( a, n); for(i=0; i<n; i++) if (a[i]==1) printf("不安全的洞号是 : %dn",i ); return 0; }
2.程序修改题
函数fun的功能是:统计a所指字符串(串中字符全部为字母)中每个字母在字符串中出现的次数(统计时不区分大小写),并将出现次数最高的字母输出(如果有多个相同,输出一个即可)。例如对于字符串dadbcdbabdbdb,对应的输出应为b或d。
请改正函数fun中指定部位的错误,使它能得出正确的结果。
注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。
#include <stdio.h> #include <string.h> void fun(char a[]) { int b[26], i, n,max; for (i=0; i<26; i++) /**********found**********/ a[i] = 0; n= strlen(a); for (i=0; i<n; i++) if (a[i] >='a' && a[i]<='z') /**********found**********/ b[a[i] - 'A']++; else if (a[i] >='A' && a[i]<='Z') b[a[i] -'A']++; max = 0; for (i=1; i<26; i++) /**********found**********/ if (b[max] > b[i]) max=i; printf("出现次数最多的字符是:%cn", max + 'a'); } int main( ) { char a[200]; printf("请输入一个待统计的字符串 : "); scanf("%s", a); fun(a); return 0; }
3.程序设计题
编写函数fun,其功能是将一个数字字符串转换成与其面值相同的长整型整数。例如,在键盘输入字符串2345210,函数返回长整型数2345210。
注意:请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
#include <stdio.h> #include <string.h> void NONO(); long fun( char *s ) { } int main() { char s[10]; long r; printf("请输入一个长度不超过9个字符的数字字符串: "); gets(s); r = fun( s ); printf(" r = %ldn" , r ); NONO(); return 0; } void NONO() {/* 本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。 */ FILE *fp, *wf ; int i; long r; char s[10], *p; fp = fopen("in.dat","r") ; wf = fopen("out.dat","w") ; for(i = 0 ; i < 10 ; i++) { fgets(s, 10, fp); p = strchr(s, 'n'); if (p) *p = 0; r = fun(s); fprintf(wf, "%ldn", r); } fclose(fp) ; fclose(wf) ; }
1.(1)0 (2)t (3)i+t 2. b[i]=0 b[a[i] - 'a']++; if (b[max] < b[i]) 3. long fun( char *s ) { long num=0; int i; for (i=0;s[i]!='