国家二级C语言机试(操作题)模拟试卷295
程序填空题
1.给定程序中,函数fun的功能是将不带头结点的单向链表逆置,即若原链表中从头至尾结点数据域依次为2、4、6、8、10,逆置后,从头至尾结点数据域依次为10、8、6、4、2。
请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。
注意:部分源程序给出如下。
不得增行或删行,也不得更改程序的结构!
试题程序:
#include<stdio.h>
#include<stdlib.h>
#define N 5
typedef struer node{
int data;
struct node*next;
}NODE;
/*********found*********/
【1】*fun(NODE*h)
{ NODE*P,*q,*r;
p=h ;
if(P==NULL)
return NULL;
q=P->next;
P->next=NULL;
while(q)
{
/*********found*********/
r=q->【2】;
q->next=p;
p=q;
/*********found*********/
q=【3】;
}
return P;
}
NODE*creatlist (int a[])
{ NODE*h,*P,*q;int i;
h=NULL;
for(i=0;i<N;i++)
{ q=(NODE*)malloc(sizeof (NODE));
q->data=a[i];
q->next=NULL;
if (h==NULL)h=p=q;
else{P->next=q;p=q;)
}
return h;
}
void outlist(NODE*h)
{ NODE*p;
p=h;
if(P==NULL)
printf(\\
(1)NODE
(2)next
(3)r
解析:填空1:本题考查了函数指针变量的函数返回值的类型,*fun(NODE,*h)的返回值为p,而p的数据类型为NODE,因此本空应该填写NODE。
填空2:从此空的形式p->可知本空应该填写next。
填空3:本题要求将不带头结点的单向链表逆置,为了使q的指针向后移,此空应该填写r。
程序修改题
2.下列给定程序中,函数fun的功能是:求k!(k<13),所求阶乘的值作为函数值返回。例如,若k=10,则应输出3628800。
请改正程序中的错误,使它能得出正确的结果。
注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!
试题程序:
#include<conjo.h>
#include
long fun(int k)
{
/*********found*********/
if k>1
return(k*fun(k-1));
Eeturn 1;
}
main()
{
int k=10;
printf(\\
if(k>1)
解析:本题考查:if语句,考生需要根据题意来确定if语句是否是正确的,if条件语句经常考,考生需掌握。
语法错误,if条件表达式应写在小括号内。
程序设计题
3.请编一个函数void fun(int tt[M][N],int PP[N]),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];/*假设各列中的第一个元素最大*/
for(i=0;i<M;i++)
if(tt[i][j]>max)/
*如果各列中的其他元素比最大值大,则将这个更大的元素看做当前该列中最大元素*/
max=tt[i][j];
pp[j]=max;/*将各列的最大值依次放入pp数组中*/
}
}
解析:本题中函数的功能是求出二维数组中每列的最大元素。首先,假设各列中的第一个元素最大,然后利用行标值的移动来依次取得各列中其他元素的值,并与假设的最大值进行比较,如果遇到更大的,则把这个更大的元素看做当前该列中最大的元素,继续与该列中其他元素进行比较。
本文档预览:3600字符,共3059字符,源文件无水印,下载后包含无答案版和有答案版,查看完整word版点下载