就业数据资源平台
当前位置:首页 > C语言程序设计
2013年计算机二级C语言上机习题8

  填空题
  函数fun的功能是:把形参a所指数组中的奇数按原顺序依次存放到a[0]、a[1]、a[2]、……中,把偶数从数组中删除,奇数个数通过函数值返回。例如:若a所指数组中的数据最初排列为:9、1、4、2、3、6、5、8、7,删除偶数后a 所指数组中的数据为:9、1、3、5、7,返回值为5。
  请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。
  注意:源程序存放在考生文件夹下的BLANK1.C中。
  不得增行或删行,也不得更改程序的结构!
  给定源程序:
  #include
  #define N 9
  int fun(int a[], int n)
  { int i,j;
  j = 0;
  for (i=0; i if (a[i]%2==___1___)
  {
  a[j] = a[i]; ___2___;
  }
  return ___3___;
  }
  main()
  { int b[N]={9,1,4,2,3,6,5,8,7}, i, n;
  printf("\nThe original data :\n");
  for (i=0; i  n = fun(b, N);
  printf("\nThe number of odd : %d \n", n);
  printf("\nThe odd number :\n");
  for (i=0; i  }
  解题思路:
  第一处:判断a[i]是否是奇数,若是,则仍保留在原数组中a[j],所以应填:1。
  第二处:数组a中的元素位置由j来控制,每增加一个元素,则j加1,所以应填:j++。
  第三处:返回删除偶数后a所指数组中数据的元素j,所以应填:j。


  改错题
  给定程序MODI1.C中函数fun的功能是:求出两个非零正整数的最大公约数,并作为函数值返回。
  例如,若给num1和num2分别输入49和21,则输出的最大公约数为7;若给num1
  和num2分别输入27和81,则输出的最大公约数为27。
  请改正程序中的错误,使它能得出正确结果。
  注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。
  给定源程序:
  #include
  int fun(int a,int b)
  { int r,t;
  if(a  t=a; b=a; a=t;
  }
  r=a%b;
  while(r!=0)
  { a=b; b=r; r=a%b; }
  return(a);
  }
  main()
  { int num1, num2,a;
  printf("Input num1 num2: "); scanf("%d%d",&num1,&num2);
  printf("num1= %d num2= %d\n\n",num1,num2);
  a=fun(num1,num2);
  printf("The maximun common divisor is %d\n\n",a);
  }
  解题思路:
  第一处:交换值的次序有问题,所以应改为:t=a;a=b;b=t;。
  第二处:返回值错误,应改为:return(b);。

  编程题
  假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:删除字符串中所有的*号。在编写函数时,不得使用C语言提供的字符串函数。
  例如,字符串中的内容为:****A*BC*DEF*G*******,删除后,字符串中的内容应当是:ABCDEFG。
  注意: 部分源程序在文件PROG1.C中。
  请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入
  你编写的若干语句。
  给定源程序:
  #include   来源:www.examda.com
  void fun( char *a )
  {
  }
  main()
  { char s[81];
  printf("Enter a string:\n");gets(s);
  fun( s );
  printf("The string after deleted:\n");puts(s);
  NONO();
  }
  解题思路:
  本题是考察字符串的操作。
  1. 利用循环扫描字符串中所有的字符是否是'*',如果不是'*',则把这些字符存放字符串a首地址开始的位置上。
  2. 最后给字符串a加上结束符。
  参考答案:
  void fun( char *a )
  {
  int j =0 ;
  char *p=a;
  while(*p) {
  if(*p != '*') a[j++]=*p ;
  p++ ;
  }
  a[j]=0;
  }

就业数据资源平台