第23套:
给定程序中,函数fun的功能是:找出N×N矩阵中每列元素中的最大值,并按顺序依次存放于形参b所指的一维数组中。
 请在程序的下划线处填入正确的内容并把下划线删除, 使程序得出正确的结果。
 注意:源程序存放在考生文件夹下的BLANK1.C中。
 不得增行或删行,也不得更改程序的结构!
 给定源程序:
#include <stdio.h> 
#define N 4 
void fun(int (*a)[N], int *b) 
{ int i,j; 
for(i=0; i<N; i++) { 
/
b[i]= __1__; 
for(j=1; j<N; j++) 
if(b[i] __2__ a[j][i]) b[i]=a[j][i]; 
} 
} 
main() 
{ int x[N][N]={ {12,5,8,7},{6,1,9,3},{1,2,3,4},{2,8,4,3} },y[N],i,j; 
printf("\nThe matrix :\n"); 
for(i=0;i<N; i++) 
{ for(j=0;j<N; j++) printf("%4d",x[i][j]); 
printf("\n"); 
} 
fun(__3__); 
printf("\nThe result is:"); 
for(i=0; i<N; i++) printf("%3d",y[i]); 
printf("\n"); 
} 
解题思路:
 第一处:把每列的第1值赋值给b[i],所以应填:a[0][i]。
 第二处:如果b[i]值小于a[j][i]的值,则把a[j][i]重新赋值给b[i]中,保存最大的值, 所以应填:<。
 第三处:在主函数中,x是存放矩阵数据,y是存放每列的最大值,所以应填:x,y。
给定程序MODI1.C中函数fun的功能是: 交换主函数中两个变量的值。例如: 若变量a中的值原为8,b中的值为3。程序运行后a中的值为3, b中的值为8。
 请改正程序中的错误, 使它能计算出正确的结果。
 注意: 不要改动 main 函数, 不得增行或删行, 也不得更改程序的结构!
 给定源程序:
#include <stdio.h> 
int fun(int x,int y) 
{ 
int t; 
t=x;x=y;y=t; 
} 
main() 
{ 
int a,b; 
a=8;b=3; 
fun(&a,&b); 
printf("%d, %d\n",a,b); 
} 
解题思路:
 第一处:函数形参定义不正确,在定义第2个形参时,也应加上int。由于通过该函数实现两数交换,在C语言中,必须交换地址中的值,所以应定义为int *x,int *y。
 第二处:要交换地址中的值,不能交换地址,必须指定地址中的值,因此应改为
 t=*x;*x=*y;*y=t;。
编写函数fun, 函数的功能是求出小于或等于lim的所有素数并放在aa数组中, 函数返回所求出的素数的个数。函数fun中给出的语句仅供参考。
 注意:部分源程序在文件PROG1.C中。
 请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
 给定源程序:
#include <stdio.h> 
#define MAX 100 
int fun(int lim, int aa[MAX]) 
{ 
int i,j,k=0; 
/* 其中变量k用于统计素数个数 */ 
for(i=2;i<=lim;i++) 
{ 
/* 以下完成判断aa数组中小于或等于lim的素数并统计个数 */ 
} 
return k; 
} 
main() 
{ 
int limit, i, sum; 
int aa[MAX] ; 
printf("输入一个整数"); 
scanf("%d", &limit); 
sum=fun(limit, aa); 
for(i=0 ; i < sum ; i++) { 
if(i % 10 == 0 && i != 0) printf("\n") ; 
printf("%5d", aa[i]) ; 
} 
NONO(); 
} 
解题思路:
 本题是考察考生如何判断一个数是素数,再求出所有小于lim数的素数并存入数组aa中保存,最后由形参aa返回,素数的个数由函数值返回。
 参考答案:
int fun(int lim, int aa[MAX]) 
{ 
int i,j,k=0; 
/* 其中变量k用于统计素数个数 */ 
for(i=2;i<=lim;i++) 
{ 
/* 以下完成判断aa数组中小于或等于lim的素数并统计个数 */ 
for(j = 2 ; j <= (i/2) ; j++) 
if(i % j == 0) break; 
if(j > (i/2)) aa[k++] = i; 
} 
return k; 
}