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

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

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

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

程序填空题

1.给定程序中,函数fun的功能是:

用函数指针指向要调用的函数,并进行调用。规定在【2】处使f指向函数f1,在【3】处使f指向函数f2。

当调用正确时,程序输出:

x1=5.000000,x2=3.000000,x1*x1+x1*x2=40.000000。

注意:部分源程序在文件BIANK1.C中。

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

试题程序:

#include<stdio.h>

double f1(double x)

{return x*xj)

double f2(double x,double y)

{return x*y;}

double fun(double a,double b)

{

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

【1】(,Ic f)();

double r1,r2;

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

f=【2】

r1=f(a);

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

f=【3】

r2=(*f)(a,b);

return r1+r2;

}

main()

(double x1=5,x2=3,r;

r=fun(x1,x2);

printf(\\

(1)double

(2)f1

(3)f2

解析:填空1:(*f)()代表一个指向函数的指针变量,而本题所被调用的f1、f2两函数的返回值均为double型,因而此空应该填写double。

填空2:因为在给函数指针变量赋值时,只需给出函数名而不必给出参数,因而此空应该填写f1。

填空3:同填空2,此空应该填写f2。

相关知识点:

(1)指向函数的指针变量的一般定义形式为:数据类型(*指针变量名)();

(2)函数的调用可以通过函数名调用,也可以通过函数指针调用。

(3)在给函数指针变量赋值时,只需给出函数名而不必给出参数。

程序修改题

2.下列给定程序是建立一个带头结点的单向链表,并用随机函数为各结点赋值。函数fun的功能是将单向链表结点(不包括头结点)数据域为偶数的值累加起来,并且作为函数值返回。

请改正函数fun中的错误,使它能得出正确的结果。

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

试题程序:

#include<stdio.h>

#include<conio.h>

#include<stdlib.h>

typedef struct aa

{int data;

struct aa*next;

}NODE;

int fun(NODE,* h)

{int sum=0;

NODE*P;

p=h一>next;

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

while(P一>next)

{if(P一>data%2==0)

sum+=P一>data;

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

p=h一>next;

}

Eeturn sHm;

)

NODE*creatlink(int n)

{

NODE *h,*p,*s;

int i;

h=p=(NODE *)malloc(sizeof

(NODE));

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

{

s=(NODE*)malloc(sizeof

(NODE));

s一>data=rand()%16;

s一>next=P一>next;

p一>next=s;

p=p一>next;

}

p一>next=NULL;

return h;

}

outlink(NODE*h)

{NODE*p;

P=h一>next;

printf (\\

(1)while (p!=NULL)

(2)p =p 一>next;

解析:(1)判断当前指针p指向的结点是否存在,若存在则对该结点数据域进行判断操作。

(2)判断结束后指针指向下一个结点。

程序设计题

3.请编写函数fun,该函数的功能是:判断字符串是否为回文,若是,则函数返回1,主函数中输出\\

int fun(char*str)

{

int i,n =0,fg =1;

char *p=str;

while(*p)/*将指针p置位到

字符串末尾,并统计字符数*/

{

n++;

p++;

}

for(i=0;i<n/2 ; i++)/*循环比较字符*/

if(str[i==str[n-1-1]);

/*相同,什么都不作*/

else/*不同,直接跳出循环*/

{

fg =0;

break;

}

return fg;

}

解析:判断回文就是将第一个字符与最后一个字符比较,第二个字符与倒数第二个字符进行比较,依此类推,直到中间的字符,如果比较的结果都相同,那么这个字符串就是回文,否则不是。程序中循环语句用来遍历字符串,条件语句用来判断当前字符与对应位置的字符是否相同。

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

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

推荐资源

客服

扫码添加客服微信

热线

官方客服

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

电话客服:

客服微信:pujinet

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

公众号

扫码关注微信公众号