知ing

最新计算机二级C语言上机试题汇编100套

NCRE研究组 编 / 高等教育出版社

゛Zirro、Y 上传

查看本书

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++) { 

/ **********found**********/ 

b[i]= __1__; 

for(j=1; j<N; j++) 

/ **********found**********/ 

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"); 

/ **********found**********/ 

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> 

/ *********found**********/ 

int fun(int x,int y) 

int t; 

/ *********found**********/ 

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; 

※※※※※※※※※※※※※※※※※※※※※※※※※ 


查看更多