国家二级(C语言)机试模拟试卷1001
程序填空题
1.使用VC++2010打开考生文件夹下blankl中的解决方案。此解决方案的项目中包含一个源程序文件blankl.c。在此程序中,函数fun()的功能是将不带头节点的单向链表节点数据域中的数据从小到大排序。即若原链表节点数据域从头至尾的数据为10、4、2、8、6,排序后链表节点数据域从头至尾的数据为2…4 6 8、10。
请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。
注意:部分源程序给出如下。
不得增行或删行,也不得更改程序的结构!
试题程序:
#include <stdio.h>
#include <stdlib.h>
#define N 6
typedef struct node{
int data;
struct nOde *next;
}NODE;
void fun(NODE *h)
{ NODE *p,*q;int t;
p=h;
while(p){
/*********found*********/
q=【1】;
/*********found*********/
while(【2】)
{if(p->data>q->data)
{t=p->data;
p->data=q->data;
q->data=t;)
q=q->next;
}
/*********found*********/
p=【3】;
}
}
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)p->next (2)q (3)p->next
解析:填空1:从第2个while循环可知,q的初值应该为p的next,故空1处应该填p->next。
填空2:第2个while循环表示的是每次从链表剩下的节点中找出最小的数,因此应该以q是否为空来判断循环是否结束。故空2处应该填q。
填空3:当找到一个最小的数时p应该向后移,故空3处应该填p->next。
程序修改题
2.使用VC++2010打开考生文件夹下modil中的解决方案。此解决方案的项目中包含一个源程序文件modil.c。在此程序中,函数fun()的功能是将s所指字符串中的字母转换为字母序列的后续字母(如“z”转换为“A”,“z”转换为“a”),其他字符不变。
请改正程序中的错误,使它能得出正确的结果。
注意:不要改动main()函数,不得增行或删行。也不得更改程序的结构!
试题程序:
#include <stdlib.h>
#include <stdio.h>
#include <ctype.h>
#include <conio.h>
void fun(char *s)
{
/*********found*********/
while(*s!=’@’)
{
if(*s>=’A’&&*s<=’Z’∣∣*s>=’a’&&*s<=’z’)
{
if(*s==’Z’) *s=’A’;
else if(*s==’z’)*s=’a’;
else *s+=1;
}
/*********found*********/
(*s)++;
}
}
void main()
{
char s[80];
system(\\
(1)while(*s)或while(*s!=’\0’)
(2)s++;
解析:(1)通过while语句可对字符串所有字符进行遍历,循环条件是对当前字符进行判断,若当前字符不是字符串结束标志,则对其进行其他操作。
(2)因为该循环通过指针s的移动遍历字符串,所以每循环一次要使指针向后移动一个位置,而不是将指针所指的元素加1。
程序设计题
3.使用VC++2010打开考生文件夹下progl中的解决方案。此解决方案的项目中包含一个源程序文件progl.c。在此程序中,请编写函数fun(),其功能是移动一维数组中的内容,若数组中有n个整数,要求把下标为0~p(含p,p不大于n-1)的数组元素平移到数组的最后。
例如,一维数组中的原始内容为1、2、3、4、5、6、7、8、9、10;p的值为3。移动后,一维数组中的内容应为5、6、7、8、9、10、1、2、3、4
注意:部分源程序给出如下。
请勿改动主函数main()和其他函数中的内容.仅在函数fun()的花括号中填入你编写的若干语句。
试题程序:
#include <stdio.h>
#define N 80
void fun(int *w,int p,int n)
{
}
main()
{int a[N]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15);
int i,p,n=15;
printf(\\
void fun(int *w,int p,int n)
{ int i,j,ch;
for(i=0;x<=p;x++)
{ ch=w[0];
for(j=1;j<n;j++)/*通过for循环语句,将p+1~n-1(含n-1)的数组元素依次向前移动p+1个存储单元*/
{
w[j-1]=w[j];
}
w[n-1]=ch;/*将下标为0~p的数组元素逐一赋给数组w[n一1]*/
}
}
解析:本题要求把下标为0~p(含p,p不大于n-1)的数组元素平移到数组的最后。可以根据输入的p值,通过for循环语句,将p+1~n-1(含n-1)的数组元素依次向前移动p+1个存储单元,即w[j-1]=w[j];。同时将下标为0~p的数组元素逐一赋给数组w[n-1],也就是通过语句w[n-1]=ch;来实现此操作。
本文档预览:3600字符,共3571字符,源文件无水印,下载后包含无答案版和有答案版,查看完整word版点下载