首页 > 全部 > 二级C语言 > 国家二级C语言机试(操作题)模拟试卷602

国家二级C语言机试(操作题)模拟试卷602

本单篇文档共3210字,内容预览3600字,预览为有答案版,源文件无水印,下载后包含无答案空白卷版和有答案版,同时也有计算机类NCRE全国计算机二级整科真题模拟题,讲义课件,思维导图,易错高频题等下载。
二级C语言 章节练习 7435人下载
价格: 2.00 原价:¥9.00
收藏

国家二级C语言机试(操作题)模拟试卷602

程序填空题

1.使用VC++2010打开考生文件夹下blank1中的解决方案。此解决方案的项目中包含一个源程序文件blank1.c。在此程序中,函数fun的功能是将不带头结点的单向链表逆置,即若原链表中从头至尾结点数据域依次为2、4、6、8、10,逆置后,从头至尾结点数据域依次为10、8、6、4、2。

请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。

注意:部分源程序给出如下。

不得增行或删行,也不得更改程序的结构!

试题程序:

#include<stdio.h>

#include<stdlib.h>

#define N5

typeclef struct 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.使用VC++2010打开考生文件夹下modi1中的解决方案。此解决方案的项目中包含一个源程序文件modi1.c。在此程序中,函数fun的功能是:在字符串的最前端加入n个*号,形成新串,并且覆盖原串。

字符串的长度最长允许为79。

请改正程序中的错误,使它能得出正确的结果。

注意:部分源程序在文件NODI1.C中,不要改动main函数,不得增行或删行,也不得更改程序的结构!

试题程序:

#include<stdio.h>

#include<string.h>

void fun(char s[],int n)

{

char a[80],*p;

int i;

/*********found*********/

s=p;

for(i=0;i<n;i++)a[i]=’*’;

do

{a[i]=*p;

i++;

}

/*********found*********/

while(*p++)

a[i]=0;

strcpy(s,a);

}

main()

(int n;char s[80];

printf(\\

(1)p=s;

(2)while(*p++);

解析:(1)指针p应指向s,所以应改为p=s;。

(2)循环等待,当while循环执行一次,临时变量p应该指向字符串的下一位置,所以应改为while(*p++);。

程序设计题

3.使用VC++2010打开考生文件夹下prog1中的解决方案。此解决方案的项目中包含一个源程序文件prog1.c。在此程序中,请编写函数void fun(int x,int pp[],int*n),它的功能是:求出能整除x且不是偶数的各整数,并按从小到大的顺序放在pp所指的数组中,这些除数的个数通过形参n返回。

例如,若x中的值为30,则有4个数符合要求,它们是1、3、5、15。

注意:部分源程序在文件PROG1.c中。

请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。

试题程序:

#include<conio.h>

#include<stdio.h>

#include<stdlib.h>

void fun(int x,int pp[],int:*n)

{

}

void main()

{

FTLE*wf;

int x,aa[1000],n,i;

system(\\

void fun(int x,int pp[],int*n)

{

int i,j=0;

for(i=1;i<=x;i=i+2)/*i的初始值为1,步长为2,确保i为奇数*/

if(x%i==0)/*将能整除x的数存入数组pp中*/

pp[j++]=i;

*n=j;/*传回满足条件的数的个数*/

}

解析:本题考查:偶数的判定方法;整除的实现。

本题题干信息是:能整除x且不是偶数的所有整数。循环语句中变量i从1开始且每次增2,所以i始终是奇数。

整除的方法,已经讲过多次,这里就不再赘述了。对于本题目要求的不是偶数的判定方法,即该数对2求余不为0。除本题描述的方法外,还可以通过for循环语句直接把偶数筛出去,确保参与操作的数均为奇数。

本文档预览:3600字符,共3210字符,源文件无水印,下载后包含无答案版和有答案版,查看完整word版点下载

剩余未完,查看全文
收藏
国家二级C语言机试(操作题)模拟试卷602

推荐资源

客服

扫码添加客服微信

热线

官方客服

如遇问题,请联系客服为您解决

电话客服:

客服微信:pujinet

工作时间:9:00-18:00,节假日休息

公众号

扫码关注微信公众号