国家二级C语言机试(操作题)模拟试卷659
程序填空题
1.使用VC++2010打开考生文件夹下blank1中的解决方案。此解决方案的项目中包含一个源程序文件blank1.c。在此程序中,函数fun的功能是:在形参s所指字符串中寻找与参数c相同的字符,并在其后插入一个与之相同的字符,若找不到相同的字符则不做任何处理。
例如,若s所指字符串为“baacda”,c中的字符为a,执行后s所指字符串为“baaaacdaa”。
请在程序的下画线处填入正确的内容并将下画线删除,使程序得出正确的结果。
注意:部分源程序给出如下。
不得增行或删行,也不得更改程序的结构!
试题程序:
#include<stdio.h>
void fun(char*s,char c)
{int i,j,n;
/*********found*********/
for(i=0;s[i]!=【1】;i++)
if(s[i]==c)
{
/*********found*********/
n=【2】;
while(s[i+1+n]!=’\0’)
n++;
for(j=i+n+1;j>i;
j–)
s[j+1]=s[j];
/*********found*********/
s[j+1]=【3】;
i=i+1;
}
}
main()
{char s[80]=\\
(1)’\0’
(2)0
(3)c
解析:填空1:for语句循环条件是判断是否到达字符串结尾,即当前字符是否为’\0’。
填空2:while语句用以确定字符串的长度,所以变量n赋初值为0。
填空3:题目要求如果找到与参数c相同的字符,就在后面插入一个相同的字符,且找到后应该给数组元素赋值,本题目给出参数为c。=
程序修改题
2.使用VC++2010打开考生文件夹下modi1中的解决方案。此解决方案的项目中包含一个源程序文件modil.c。在此程序中,函数Creatlink的功能是:创建带头结点的单向链表,并为各结点数据域赋0到m-1的值。
请改正函数Creatlink中指定部位的错误,使它能得出正确的结果。
注意:部分源程序在文件MODI1.C中,不要改动main函数,不得增行或删行,也不得更改程序的结构!
试题程序:
#include<stdio.h>
#include<stdlib.h>
typedef struct aa
(int data;
Struct aa*next;
}NODE;
NODE*Creatlink(int n,intm)
{NODE*h=NULL,*p,*s;
int i;
/*********found*********/
p=(NODE)malloc(sizeof(NODE));
h=p;
p->next=NULL;
for(i=1;i<=n;i++)
{s=(NODE*)malloc(Sizeof(NODE));
s->data=rand()%m;
s->next=p->next;
p->next=s;p=p->next;
}
/*********found*********/
return p;
}
outlink(NODE*h)
{NODE*p;
p=h->next;
printf(\\
(1)p=(NODE*)malloc(sizeof(NODE));
(2)returnh;
解析:(1)由变量定义可知p为指向结点的指针。指向刚分配的结构指针,所以应改为p=(NODE*)malloc(sizeof(NODE))。
(2)在动态分配内存的下一行语句是,使用临时结构指针变量h保存p指针的初始位置,最后返回不能使用p,是因为p的位置已经发生了变化,所以应改为returnh。
程序设计题
3.使用VC++2010打开考生文件夹下prog1中的解决方案。此解决方案的项目中包含一个源程序文件prog1.C。在此程序中,规定输入的字符串中只包含字母和*号。请编写函数fun,其功能是:使字符串的前导*号不得多于n个,若多于n个,则删除多余的*号;若少于或等于n个,则不做处理。字符串中间和尾部的*号不删除。
例如,字符串中的内容为“*******A*BC*DEF*G****”,若n的值为4,删除后,字符串中的内容应当是“****A*BC*DEF*G****”;若n的值为8,则字符串中的内容仍为“*******A*BC*DEF*G****”。n的值在主函数中输入。在编写函数时,不得使用C语言提供的字符串函数。
注意:部分源程序给出如下。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
试题程序:
#include<stdio.h>
#include<conio.h>
void fun(char*a,int n)
{
}
void main()
{
char s[81];int n;
printf(\\
void fun(char*a,int n)
{
inti:0,k=0;
char*p,*t;
p=t=a;/*开始时,p与t同时指向数组的首地址*/
while(爿ct==’*’)/*用k来统计前部星号的个数*/
{k++;t++;}
if(k>n)/*如果k大于n,则使p的前部保留n个星号,其后的字符依次存入数组a中*/
{while(*p)
{a[i]=*(p+k-n);
i++;
p++;
}
a[i]=’\0’;/*在字符串最后加上结束标识*/
}
}
解析:字符串中前导*号不能多于n个,多余的应删除。首先需要通过while循环统计字符串前导*号的个数,然后通过if条件语句完成前导*号的个数和n的比较,如果前导术号多于n个,需要把n个*号和其余字符重新保留。
本文档预览:3600字符,共3196字符,源文件无水印,下载后包含无答案版和有答案版,查看完整word版点下载