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

  填空题
  给定程序中,函数fun的功能是:在形参ss所指字符串数组中,删除所有串长超过k的字符串,函数返回所剩字符串的个数。ss所指字符串数组中共有N个字符串,且串长小于M。
  请在程序的下划线处填入正确的内容并把下划线删除, 使程序得出正确的结果。
  注意:源程序存放在考生文件夹下的BLANK1.C中。
  不得增行或删行,也不得更改程序的结构!
  给定源程序:
  #include <stdio.h>
  #include <string.h>
  #define N 5
  #define M 10
  int fun(char (*ss)[M], int k)
  { int i,j=0,len;
  for(i=0; i< __1__ ; i++)
  { len=strlen(ss[i]);
  if(len<= __2__)
  strcpy(ss[j++],__3__);
  }
  return j;
  }
  main()
  { char x[N][M]={"Beijing","Shanghai","Tianjing","Nanjing","Wuhan"};
  int i,f;
  printf("\nThe original string\n\n");
  for(i=0;i<N;i++)puts(x[i]); printf("\n");
  f=fun(x,7);
  printf("The string witch length is less than or equal to 7 :\n");
  for(i=0; i<f; i++) puts(x[i]);printf("\n");
  }
  解题思路:
  本题是根据给定的字符串数组中删除串长大于某个值的字符串。
  第一处:利用for循环,从几个字符串中进行查找,程序中已经给定了N个字符串,所以应填:N。
  第二处:串长由形参k来传递,所以应填:k。
  第三处:如果字符串ss[i]的串长小于k,则该字符串仍存在原字符串数组中,位置由变量j 来控制,所以应填:ss[i]。


  改错题
  给定程序MODI1.C中函数fun的功能是:逐个比较p、q所指两个字符串对应位置中的字符,把ASCII值大或相等的字符依次存放到c所指数组中,形成一个新的字符串。
  例如,若主函数中a字符串为:aBCDeFgH,
  主函数中b字符串为:ABcd,
  则c中的字符串应为:aBcdeFgH。
  请改正程序中的错误,使它能得出正确结果。
  注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。
  给定源程序:
  #include <stdio.h>
  #include <string.h>
  void fun(char *p ,char *q, char *c)
  {
  int k = 1;
  while( *p != *q )
  { if( *p<*q ) c[k]=*q;
  else c[k]=*p;
  if(*p) p++;
  if(*q) q++;
  k++;
  }
  }
  main()
  { char a[10]="aBCDeFgH", b[10]="ABcd", c[80]={'\0'};
  fun(a,b,c);
  printf("The string a: "); puts(a);
  printf("The string b: "); puts(b);
  printf("The result : "); puts(c);
  }
  解题思路:
  第一处: 存放字符串初始位置也是从0开始存放的,由于k是控制c字符串的位置值,所以k值应为0。
  第二处: 判断两个字符串中是否有字符串结束符产生,所以应改为:while( *p || *q ),
  而不是两字符串中对应位置的值不相等。

  编程题
  假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:除了字符串前导的*号之外,将串中其它*号全部删除。在编写函数时,不得使用C语言提供
  的字符串函数。函数fun中给出的语句仅供参考。
  例如,字符串中的内容为:****A*BC*DEF*G*******,删除后, 字符串中的内容应当是:****ABCDEFG。
  注意: 部分源程序在文件PROG1.C文件中。
  请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
  给定源程序:
  #include <stdio.h>
  void fun( char *a )
  {
  int i=0,k;
  while(a[i]=='*') i++;
  k=i+1;
  while(a[i]!='\0') /* 以下程序段实现非*字符前移 */
  {
  }  


  a[i+1]='\0';
  }
  main()
  { char s[81];
  printf("Enter a string:\n");gets(s);
  fun( s );
  printf("The string after deleted:\n");puts(s);
  NONO();
  }
  解题思路:
  本题是考察字符串的操作。
  1. 使用while循环语句求出字符串前导*号的个数。
  2. 使用while循环语句判断a[i]是否是字符串结束符标志,如果不是字符串结束标志,则再判断是否是字符*号,如果不是*号,则把a[i]字符存入a[k]中,如果是*号则跳过该*号,直至字符串结束为止。
  参考答案:
  void fun( char *a )
  {
  int i=0,k;
  while(a[i]=='*') i++;
  k=i;
  while(a[i]!='\0') /* 以下程序段实现非*字符前移 */
  {
  if(a[i] != '*') a[k++]=a[i];
  i++;
  }
  a[k]='\0';
   }

就业数据资源平台