国家二级C语言机试(操作题)模拟试卷373
程序填空题
1.函数fun的功能是:把形参a所指数组中的奇数按原顺序依次存放到a[0]、a[l]、a[2]、……中,把偶数从数组中删除,奇数个数通过函数值返回。例如:
若a所指数组中的数据最初排列为:9、1、4、2、3、6、5、8、7,删除偶数后a所指数组中的数据为:9、l、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<n;i++)
/*********found**********/
if(a[i]%2==____1____)
{
/*********found**********/
a[j]=a[i];____2____;
}
/*********found**********/
return ____3____ ;
}
main ()
{ int b [N]={ 9,1,4,2,3,6,5,8,7 } ,i,n;
printf (\\
(1)1
(2)j++
(3)j
解析:函数fun的功能是把形参a所指数组中的奇数按原顺序依次存放到a中。
第一空:根据“a[j]=a[i];”可知,a[i]是奇数,变量j记录奇数的个数,故第一空处是判断a[i]是否是奇数,故第一空处应为“1”。
第二空:变量j记录奇数的个数,故第二空处j计数应当加1,因此第二空处应为“j++”或“j=j+1”。
第三空:fun函数的返回值是奇数个数,故第三空处应为“j”。
程序修改题
2.给定程序MODI1.C中函数fun的功能是:求出两个非零正整数的最大公约数,并作为函数值返回。
例如,若给numl和num2分别输入49和21,则输出的最大公约数为7;若给numl和num2分别输入27和81,则输出的最大公约数为27。
请改正程序中的错误,使它能得出正确结果。
注意:不要改动mam函数,不得增行或删行,也不得更改程序的结构。
#include
int fun (int a,int b)
{ int r,t;
if(a<b){
/*********found**********/
t=a; b=a; a=t;
}
r=a%b;
while (r ! =0)
{a=b;b=r;r=a%b;}
/*********found**********/
return (a) ;
}
main ()
{ int numl,num2,a;
printf(\\
(1)t=a; a=b; b=t;
(2) return (b);
解析:函数的功能是求出两个非零正整数的最大公约数。
(1)根据算法分析,首先要确保a、b两个数中a是较大数,b是较小数,如果不是,则交换a和b。但是第一个标识下,交换a和b两个数的算法有误,所以应将“t=a,b=a;a=t;”改为“t=a;a=b;b=t;”。
(2)算法到循环结束,最后余数为0的时候,b中所存的数即为最大公约数,也就是函数要返回的值。因此,第二个标识下面的“return (a),”改为“retum (b); ”。
程序设计题
3.假定输入的字符串中只包含字母和“*”号。请编写函数fun,它的功能是:删除字符串中所有的“*”号。在编写函数时,不得使用C语言提供的字符串函数。
例如,字符串中的内容为:****A*BC*DEF*G******,删除后,字符串中的内容应当是:ABCDEFG。
注意:部分源程序在文件PROG1.C中。
请勿改动主函数mam和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
#include
void fun (char *a)
{
}
main()
{char s[81];
void NONO ();
printf (\\
1 int j=0;
2 char *p=a;
3 while(* p){
4 if (*p !=’* ’)a[j++]=* p;
5 p++; )
6 a[j]=’\\\\0’;
解析:该程序功能是删除字符串中所有的*号。解题思路是在while循环过程中,利用if判断表达式判断每一个字符是否为“*”号,如果不是将其拷贝到字符串,否则跳过,这样就实现了函数功能。
本文档预览:3600字符,共2621字符,源文件无水印,下载后包含无答案版和有答案版,查看完整word版点下载