读书人

2013年C语言计算机二级上机练习模拟题

发布时间: 2013-06-22 13:25:04 作者: luck

  填空题

  给定程序中,函数fun的功能是建立一个N×N的矩阵。 矩阵元素的构成规律是:最外层元素的值全部为1;从外向内第2层元素的值全部为2;第3层元素的值

  全部为3,…依次类推。例如,若N=5,生成的矩阵为:

  1 1 1 1 1

  1 2 2 2 1

  1 2 3 2 1

  1 2 2 2 1

  1 1 1 1 1

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

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

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

  给定源程序:

  #include

  #define N 7

  void fun(int (*a) __1__)

  { int i,j,k,m;

  if(N%2==0) m=N/2 ;

  else m=N/2+1;

  for(i=0; i<m; p="" {

  for(j= __2__ ; j<n-i; p="" j++)

  a[i][j]=a[N-i-1][j]=i+1;

  for(k=i+1; k<n-i; p="" k++)

  a[k][i]=a[k][N-i-1]= __3__;

  }

  }

  main()

  { int x[N][N]={0},i,j;

  fun(x);

  printf("\nThe result is:\n");

  for(i=0; i<n; p="" i++)

  { for(j=0; j<n; p="" j++)="" printf(?%3d?,x[i][j]);

  printf("\n");

  }

  }

  解题思路:

  第一处:建立一个N×N的矩阵,所以应填:[N]。

  第二处:j的起始变量值应i。

  第三处:也应该填写i+1。


  改错题

  给定程序MODI1.C中函数 fun 的功能是: 将十进制正整数m转换成k(2≤k≤9) 进制数, 并按高位到低位顺序输出。

  例如,若输入8和2,则应输出1000(即十进制数8转换成二进制表示是1000)。

  请改正 fun 函数中的错误,使它能得出正确的结果。

  注意:不要改动 main 函数。不得增行或删行,也不得更改程序的结构!

  给定源程序:

  #include

  #include

  void fun( int m, int k )

  {

  int aa[20], i;

  for( i = 0; m; i++ )

  {

  aa[i] = m/k;

  m /= k;

  }

  printf( "%d", aa[ i ] );

  }

  main()

  {

  int b, n;

  printf( "\nPlease enter a number and a base:\n" );

  scanf( "%d %d", &n, &b );

  fun( n, b );

  printf("\n");

  }

  解题思路:

  第一处:应该取模而不是整除,所以应为:aa[i]=m%k;。

  第二处:输出aa的位置不正确,所以应为:printf("%d",aa[i-1]);。


  编程题

  编写一个函数,从num个字符串中找出最长的一个字符串,并通过形参指针max传回该串地址。(注意: 主函数中用****作为结束输入的标志,函数fun中给出的语句仅供参考。)

  注意:部分源程序在文件PROG1.C中。

  请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。

  给定源程序:

  #include

  #include

  fun(char(*a)[81],int num,char **max)

  {

  int i,k=0,len, maxlen; /* k为a数组中最长串所在元素的下标,初始为0,maxlen为其串

  长 */  来源:考试大

  maxlen=strlen(a[k]);

  for(i=1;i

  {

  /* 以下完成查找最长串 */

  }

  *max=a[k];

  }

  main()

  {

  char ss[10][81],*ps;

  int n,i=0;

  printf("输入若干个字符串:");

  gets(ss[i]);

  puts(ss[i]);

  while(!strcmp(ss[i],"****")==0)

  {

  i++;

  gets(ss[i]);

  puts(ss[i]);

  }

  n=i;

  fun(ss,n,&ps);

  printf("\nmax=%s\n",ps);

  NONO();

  }

  解题思路:

  本题是考察考生怎样从已输入的字符串中找出长度最大的字符串。求字符串的长度可以使用strlen函数。

  参考答案:

  fun(char(*a)[81],int num,char **max)

  {

  int i,k=0,maxlen; /* k为a数组中最长串所在元素的下标,初始为0,maxlen为其串长 */

  maxlen=strlen(a[k]);

  for(i=1;i

  {

  /* 以下完成查找最长串 */

  if(strlen(a[i]) > maxlen) {

  maxlen = strlen(a[i]) ;

  k = i ;

  }

  }

  *max=a[k];

  }

更多关注:

3月份计算机一级考试微机知识预测整理汇总

2013年计算机等级考试一级微机考题预测汇总

计算机二级C语言上机题考前预测汇总

2013年计算机二级C语言考试预测及答案汇总

3月计算机一级MS Office自测题附答案汇总

3月份计算机二级C语言上机练习题及答案汇总

更多精彩请关注读书人网计算机频道!


读书人网 >二级考试

热点推荐