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

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

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

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

程序填空题

1.使用VC++2010打开考生文件夹下blank1中的解决方案。此解决方案的项目中包含一个源程序文件blank1.c。在此程序中,已建立一个带头结点的单向链表,链表中的各结点按结点数据域中的数据递增有序链接。函数fun的功能是:把形参X的值放人一个新结点并插入链表中,使插入后各结点数据域中的数据仍保持递增有序。

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

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

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

试题程序:

#include<stdio.h>

#include<stdlib.h>

#define N8

typedef struct list

{int data;

struct iist*next;

}SLTST;

void fun(SLTST*h,int x)

{SLTST*p,*q,*s;

s=(SLIST*)malloc(siZeof

(SLIST));

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

s->data=【1】

q=h;

p=h->next;

while(p!=NULL&&x>p->data){

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

q=【2】

p=p->next;

}

s->next=p;

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

q->next=【3】

}

SLIST*creatlist(int*a)

{SLIST*h,*p,*q;int i;

h=p=(SLIST*)malloc(sizeof(SLIST));

for(i=0;i<N;i++)

{q=(SLIST*)malloc(sizeof(SLIST));

q->data=a[i];p->next=q;

p=q;

}

p->next=0;

returnh;

}

void outlist;(SLIST,*h)

{SLIST*p;

p=h->next;

if(p==NULL)

printf(\\

(1)x

(2)p

(3)s

解析:填空1:将形参x赋值给结点的数据域。

填空2和填空3:将新的结点和原有链表中的结点进行比较。

程序修改题

2.使用VC++2010打开考生文件夹下modi1中的解决方案。此解决方案的项目中包含一个源程序文件modi1.c。程序的功能是:读入一个整数k(2≤k≤10000),输出它的所有质因子(即所有为素数的因子)。例如,若输入整数2310,则应输出:2,3,5,7,11。

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

注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!

试题程序:

#include<conio.h>

#include<stdio.h>

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

IsPrime(int n);

{

int i,m;

m=1;

for(i=2;i<n;i++)

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

if!(n%i)

{m=0;break;)

return(m);

}

main()

{

int j,k;

printf(\\

(1)IsPrime(int n)

(2)if(!(n%i))

解析:(1)函数定义格式错误,函数定义时后面不能加“;”,所以应该去掉分号。

(2)根据题意可知,if条件语句判断n是否可以整除i,如果不能整除则为质因子,所以if!(n%i)应改为if(!(n%i))。

程序设计题

3.使用VC++2010打开考生文件夹下prog1中的解决方案。此解决方案的项目中包含一个源程序文件prog1.c。在此程序中,请编写函数fun,其功能是:将M行N列的二维数组中的字符数据,按列的顺序依次放到一个字符串中。

例如,若二维数组中的数据为

W W W W

S S S S

H H H H

则字符串中的内容应是:WSHWSHWSHWSH。

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

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

试题程序:

#include<stdio.h>

#define M3

#define N4

void fun(char(*s)[N],char*b)

{

}

void main()

{

char a[100],w[M][N]={{’W’,’W’,’W’,’W’},{’S’,’S’,’S’,’S’},{’H’,’H’,’H’,’H’}};

int i,j;

printf(\\

void fun(char(*s)[N],char*b)

{

int i,j,k=0;

for(i=0;i<N;i++)/*按列的顺序依次放到一个字符串中*/

for(j=0;j<M;j++)

b[k++]=s[j][i];

b[k]=’\0’;

}

解析:看到程序后,很容易便能想到用循环嵌套的方法,本题中按列的顺序依次放到一个字符串中,所以列标变化慢,行标变化快。

注意:第1个循环条件为i<N(即列);第2个循环条件为j<M(即行),因为在循环的嵌套中越在内层,循环变化就越快。

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

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

推荐资源

客服

扫码添加客服微信

热线

官方客服

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

电话客服:

客服微信:pujinet

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

公众号

扫码关注微信公众号