就业数据资源平台
当前位置:首页 > C语言程序设计
2011年计算机二级考试C语言十套上机题(3)

  1.填空题
  请补充函数fun(),该函数的功能是:从‘a’到‘z’统计一个字符串中所有字母字符各自出现的次数,结果保存在数组alf中。注意:不区分大小写,不能使用字符串库函数。
  例如,输入:“A=abc+5*c”,结果为:a=2,b=1,c=2。
  注意:部分源程序给出如下。
  请勿改动主函数main和其他函数中的任何内容,仅在函数fun的横线上填入所编写的若干表达式或语句。
  试题程序:
  #include
  #include
  #define N 100
  void fun(char *tt,int alf[])
  {
  int i;
  char *p=tt;
  for(i=0;i<26;i++)
  【1】;
  while(*p)
  {
  if(*p>='A'&&*p<='Z')
  【2】;
  if(*p>='a'&&*p<='z')
  alf[*p-'a']++;
  【3】;
  }
  }
  main()
  {
  char str[N];
  char a='a';
  int alf[26],k;
  clrscr();
  printf("\nPlease enter a char string:");
  scanf("%s",str);
  printf("\n**The original string**\n");
  puts(str);
  fun(str,alf);
  printf("\n**The number of letter**\n");
  for(k=0;k<26;k++)
  {
  if(k%5==0)
  printf("\n");
  printf("%c=%d ",a+k,alf[k]);
  }
  printf("\n");
  }
  答案及评析:
  【1】alf[i]=0 【2】*p+=32 【3】p++
  【解析】填空1:数组alf[26]用来存放字母字符出现的次数,在使用之前需要清零。填空2:题目要求不区分大小写,所以可以先将所有的大写字母都转换为对应的小写字母,然后一并记录出现的次数。将大写字母转换为对应的小写字母,只需将ASCII码加上32就可以了。填空3:指针p指向字符串tt,通过p自加1来移动指针,访问字符串中的所有字符。


  2. 改错题
  下列给定程序中函数fun()的功能是:从低位开始取出长整型变量s中奇数位上的数,依次构成一个新数放在t中。例如,当s中的数为4576235时,t中的数为4725。
  请改正程序中的错误,使它能得到正确结果。
  注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。
  试题程序:
  #include
  #include
  /**********************found***********************/
  int fun(long s,long *t)
  {
  long s1=10;
  *t=s;
  while(s>0)
  {
  /**********************found***********************/
  s=s0;
  *t=s*s1+*t;
  s1=s1*10;
  }
  }
  main()
  {
  long s, t;
  clrscr();
  printf("\nPlease enter s: ");
  scanf("%ld",&s);
  fun(s,&t);
  printf("The result is: %ld\n ",t);
  }
  答案及评析:
  (1)错误:int fun(long s,long *t)
  正确:void fun(long s,long *t)
  (2)错误:s=s0;
  正确:s=s/100;
  【解析】错误1:函数由指针来完成参数的传递,所以没有返回值,应定义函数的类型为void。
  错误2:此处要注意特殊运算符号"%"--取余和"/"--整除的区别。将一个数整除100则可得到由其百位数以上的数组成的新数字,将一个数整除100取余则可得到由十位数和个位数组成的新数。


  3. 编程题
  请编写一个函数fun(),它的功能是:求出一个4×M整型二维数组中最小元素的值,并将此值返回调用函数。
  注意:部分源程序给出如下。
  请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。
  试题程序:
  #define M 4
  #include
  fun (int a[][M])
  {
  }
  main()
  {
  int arr[4][M]={11,3,9,35,42,-4,24,32,6,48,-32,7,23,34,12,-7};
  printf("min=%d\n",fun(arr));
  }
  答案及评析:
  fun (int a[][M])
  {
  int i,j,min=a[0][0];
  for(i=0;i<4;i++)
  for(j=0;j
  if(min>a[i][j])
  min=a[i][j]; /*求出二维数组的最小值*/
  return min;
  }
  【解析】此类求最大值或最小值的C语言问题,我们可以采用逐个比较的方式。要求数组中的所有元素走动一遍,并从中找出最大、最小值,要注意一开始应使min存放数组中的第一个元素的值。可按逐行查找也可按逐列查找的方式,本题采用的是逐行查找的方式。即行下标在外层循环,列下标在内层循环,因为在循环的嵌套中越在内层循环,循环变化就越快。

就业数据资源平台