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

  给定程序中,函数fun的功能是计算下式 

  例如,若形参e的值为1e-3,函数的返回值2.735678。 


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


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


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


  给定源程序: 


  #include  


  double fun(double e) 


  { int i; double s, x; 


  s=0; i=__1__; 


  x=1.0; 


  while(x>e){ 


  __2__; 


  x=(2.0*i-1)/((__3__)*(2.0*i)); 


  s=s+x; 


  } 


  return s; 


  } 


  main() 


  { double e=1e-3; 


  printf("\nThe result is: %f\n",fun(e)); 


  }


 解题思路: 


  第一处:根据公式以及下面的程序,可以得出i应为0。 


  第二处:根据公式以及i的初值为0,所以应填:i++。 


  第三处:根据公式要求,所以应填:2.0*i。 


  *************************************************** 


  给定程序MODI1.C中函数 fun 的功能是:将s所指字符串的正序和反序进行连接,形成一个新串放在t所指的数组中。 


  例如,当s所指字符串为:"ABCD" 时,则t所指字符串中的内容应 


  为:"ABCDDCBA"。 


  请改正程序中的错误,使它能得出正确的结果。 


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


  给定源程序: 


  #include  


  #include  


  void fun (char s, char t) 


  { 


  int i, d; 


  d = strlen(s); 


  for (i = 0; i  for (i = 0; i  t[2*d-1] = ’\0’; 


  } 


  main() 


  { 


  char s[100], t[100]; 


  printf("\nPlease enter string S:"); scanf("%s", s); 


  fun(s, t); 


  printf("\nThe result is: %s\n", t); 


  }


  解题思路: 


  第一处:从函数体fun中可知,两个均为字符指针型变量,应改为:void fun (char *s, char *t)。 


  第二处:字符串结束位置错误,应改为:t[2*d]=0;。 


  *************************************************** 


  函数fun的功能是: 将s所指字符串中除了下标为奇数、同时ASCII值也为奇 数的字符之外,其余的所有字符都删除,串中剩余字符所形成的一个新串放在t所 指的数组中。 


  例如,若s所指字符串中的内容为:"ABCDEFG12345",其中字符A的ASCII码值虽为奇数,但所在元素的下标为偶数,因此必需删除;而字符1的ASCII码值为奇数,所在数组中的下标也为奇数,因此不应当删除,其它依此类推。最后t所指的数组中的内容应是:"135"。 


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


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


  给定源程序: 


  #include  


  #include  


  void fun(char *s, char t[]) 


  { 


  } 


  main() 


  { 


  char s[100], t[100]; 


  printf("\nPlease enter string S:"); scanf("%s", s); 


  fun(s, t); 


  printf("\nThe result is: %s\n", t); 


  NONO(); 


  }


 解题思路: 


  本题是从一个字符串按要求生成另一个新的字符串。我们使用for循环语句来解决这个问


  题。 


  参考答案: 


  void fun(char *s, char t[]) 


  { 


  int i, j = 0 ; 


  for(i = 1 ; i < strlen(s) ; i += 2) 


  if(s[i] % 2) t[j++] = s[i] ; 


  t[j] = 0 ; 


  } 


  ※※※※※※※※※※※※※※※※※※※※※※※※※ 

就业数据资源平台