国家二级(C语言)机试模拟试卷1023
程序填空题
1.使用VC++2010打开考生文件夹下blankl中的解决方案。此解决方案的项目中包含一个源程序文件blankl.c。在此程序中,函数fun()的功能是将形参std所指结构体数组中年龄最大者的数据作为函数值返回,并在main()函数中输出。
请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。
注意:部分源程序给出如下。
不得增行或删行,也不得更改程序的结构!
试题程序:
#include <stdio.h>
typedef struct
{char name[10];
int age;
}STD;
STD fun(STD std[],int n)
{ STD max;int i;
/*********found*********/
max=【1】;
for(i=1;i<n;i++)
/*********found*********/
if(max.age<【2】)
max=std[i];
return max;
}
main()
{ STD std[5]={\\
(1)std[0] (2)std[i].age (3)max.name
解析:填空1:变量max用于存储数组中年龄最大的元素。首先将数组的第1个元素赋给max,然后依次向后比较,得到年龄最大的元素,因此在给max赋初值时,空1处应该填std[0]。
填空2:if条件判断语句表达的是max.age应该和结构体数组中的每个年龄进行比较,从而得到年龄最大者的数据。故空2处应该填std[i].age。
填空3:从printf()的表达式可看出,要输出的值应为年龄最大者的name。故空3处应该填max.name。
程序修改题
2.使用VC++2010打开考生文件夹下modil中的解决方案。此解决方案的项目中包含一个源程序文件modil.c。在此程序中,函数fun()的功能是实现两个整数的交换。例如,为a和b分别输入60和65,输出:a=65 b=60。
请改正程序中的错误,使它能得出正确的结果。
注意:不要改动main()函数,不得增行或删行,也不得更改程序的结构。
试题程序:
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
/*********found*********/
void fun(int a,b)
{
int t;
/*********found*********/
t=b;b=a;a=t;
}
void main()
{
int a,b;
system(\\
(1)void fun(int *a,int *b)
(2)t=*b;*b=*a;*a=t;
解析:(1)本题考查指针变量作函数参数。采用普通变量作为形参,不能改变实参的值;采用指针变量作为形参则能够改变实参的值。主函数中fun()的调用方式说明fun()函数的参数应当为指针类型。
(2)此处错误比较明显,因为变量a和b都是指针变量。进行变量交换时不能直接引用,应加上指针运算符“*”。
程序设计题
3.使用VC++2010打开考生文件夹下progl中的解决方案。此解决方案的项目中包含一个源程序文件progl.c。在此程序中,请编写函数fun(),tt指向一个M行N列的二维数组,求出二维数组每列中值最大的元素,并依次放入pp所指的一维数组中。二维数组中的元素已在主函数中给出。
注意:部分源程序给出如下。
请勿改动主函数main()和其他函数中的任何内容。仅在函数fun()的花括号中填入你编写的若干语句。
试题程序:
#include <stdlib.h>
#include <conio.h>
#include <stdio.h>
#define M 3
#define N 4
void fun(int tt[M][N],int pp[N])
{
}
void main()
{
int t[M][N]={{68,32,54,12},
{14,24,88,58},{42,22,44,56}};
int p[N],i,j,k;
system(\\
void fun(int tt[M][N],int pp[N])
{
int i,j,max;
for(j=0;j<N;j++)
{
max=tt[0][j];
/*假设各列中的第1个元素值最大*/
for(i=0;i<M;i++)
if(tt[i][j]>max)
/*如果各列中的其他元素值比最大值大,则将这个值更大的元素看作当前列中值最大的元素*/
max=tt[i][j];
pp[j]=max;/*将各列的最大值依次放入pp数组中*/
}
}
解析:本题函数fun()的功能是求出二维数组中每列值最大的元素。首先,假设各列中的第1个元素值最大,然后利用行下标的移动来依次取得各列中其他元素的值,并与假设的最大值进行比较,如果遇到更大的,则把这个值更大的元素看作当前列中值最大的元素,继续与该列中的其他元素进行比较。
本文档预览:3600字符,共2885字符,源文件无水印,下载后包含无答案版和有答案版,查看完整word版点下载