知ing

最新计算机二级C语言上机试题汇编100套

NCRE研究组 编 / 高等教育出版社

゛Zirro、Y 上传

查看本书

72套: 

给定程序中,函数fun的功能是计算下式,例如,若形参e的值为1e-3,函数的返回值2.735678。 

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

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

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

给定源程序: 

#include <stdio.h> 

double fun(double e) 

{ int i; double s, x; 

/ **********found**********/ 

s=0; i=__1__; 

x=1.0; 

while(x>e){ 

/ **********found**********/ 

__2__; 

/ **********found**********/ 

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 <stdio.h> 

#include <string.h> 

/ ************found************/ 

void fun (char s, char t) 

int i, d; 

d = strlen(s); 

for (i = 0; i<d; i++) t[i] = s[i]; 

for (i = 0; i<d; i++) t[d+i] = s[d-1-i]; 

/ ************found************/ 

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",其中字符AASCII码值虽为奇数,但所在元素的下标为偶数,因此必需删除;而字符1ASCII码值为奇数,所在数组中的下标也为奇数,因此不应当删除,其它依此类推。最后t所指的数组中的内容应是:"135"。 

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

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

给定源程序: 

#include <stdio.h> 

#include <string.h> 

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 ; 

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


查看更多