就业数据资源平台
当前位置:首页 > C语言程序设计
2014年计算机二级C语言上机模拟试题22

 给定程序中,函数fun的功能是:找出N×N矩阵中每列元素中的最大值,并按顺序依次存放于形参b所指的一维数组中。 

  请在程序的下划线处填入正确的内容并把下划线删除, 使程序得出正确的结果。 


  注意:源程序存放在考生文件夹下的BLANK1.C中。 


  不得增行或删行,也不得更改程序的结构! 


  给定源程序: 


  #include  


  #define N 4 


  void fun(int (*a)[N], int *b) 


  { int i,j; 


  for(i=0; i  /


  b[i]= __1__; 


  for(j=1; 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  { for(j=0;j  printf("\n"); 


  } 


  fun(__3__); 


  printf("\nThe result is:"); 


  for(i=0; i  }


 解题思路: 


  第一处:把每列的第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  


  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  


  #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("]", 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; 


  }

就业数据资源平台