ImageVerifierCode 换一换
格式:DOC , 页数:5 ,大小:34KB ,
资源ID:498479      下载积分:2000 积分
快捷下载
登录下载
邮箱/手机:
温馨提示:
如需开发票,请勿充值!快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝扫码支付 微信扫码支付   
注意:如需开发票,请勿充值!
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【http://www.mydoc123.com/d-498479.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文([计算机类试卷]国家二级C语言机试(操作题)模拟试卷51及答案与解析.doc)为本站会员(李朗)主动上传,麦多课文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知麦多课文库(发送邮件至master@mydoc123.com或直接QQ联系客服),我们立即给予删除!

[计算机类试卷]国家二级C语言机试(操作题)模拟试卷51及答案与解析.doc

1、国家二级 C语言机试(操作题)模拟试卷 51及答案与解析 一、程序填空题 1 给定程序中已建立一个带有头结点的单向链表,链表中的各结点按结点数据域中的数据递增有序链接。函数 fun的功能是:把形参 X的值放入一个新结点并插入到链表中,插入后各结点数据域的值仍保持递增有序。 请在程序的下划线处填入正确的内容并把下划线删除,使程序得出正确的结果。 注意:源程序存放在考生文件夹下的 BLANKl C中。 不得增行或删行,也不得更改程序的结构 ! #include #include #define N 8 typedef struct list int data; struct list *next;

2、 SLIST; VOid fun(SLIST *h, int x) SLIST *P, *q, *s; s=(SLIST *)malloc(sizeof(SLIST); /*found*/ s一 data= _1_; q=h; p=h一 next; while(P!=NULL xp一 data) /*found*/ q=_2_; p=P一 next; s一 next=p; /*found*/ q一 rlext=_3_ ; SLIST *creatlist(int *a) SLIST *h, *p, *q; int i; h=p=(SLIST *)malloc(sizeof(SLIST); fo

3、r(i=0; idata=ai; P一 next=q;p=q; P一 next=0; return h; void outliSt(SLIST *h) SLIST*P; p=h一 next; if(p=NULL)printf(“ nThe list is NULL! n”); else printf(“ nHead”); doprintf(“一 d”, P一 data); P=P一 next; )while(P!=NULL); printf(“一 End n”); main() SLIST *head; int X; int aN=(11, 12, 15, 18, 19, 22, 25, 29

4、); head=creatjst(a); printf(“ nThe list before inserting: n”); outlist(head); printf(“ nEnter a number: ”); Scanf(“ d”, &x); fun(head, X); printf(“ nThe list after inserting: n”); outliSt(head); 二、程序修改题 2 给定程序 MODll C中 fun函数的功能是:根据整型形参 m,计算如下公式的值。 例如,若主函数中输入 5,则应输出 -0 283333。 请改正函数 fun中的错误或在横线处填上适当的

5、内容并把横线删除,使它能计算出正确的结果。 注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构 !#includedouble fun(int m) double t=1 0; int i; for(i=2; i 三、程序设计题 3 编写函数 fun,它的功能是:利用以下所示的简单迭代方法求方程: cos(x)-x=0的一个实根。 xn+1=cos(Xn) 迭代步骤如下: (1)取 x1初值为 0 0; (2)x0=x1,把 x1的值赋给 x0; (3)x1=cos(x0),求出一个新的 x1; (4)若 x0 x1的绝对值小于0 000001,执行步骤 (5),否则执行步骤

6、(2); (5)所求 x1就是方程 cos(x)一 x=0的一个实根,作为函数值返回。 程序将输出结果 Root=0 739086。 注意:部分源程序在文件 PROGl C中。 请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun的花括号中填入你编写的若下语句。 #include #include double fun() main() void NONO(); printf(“Root= f n”, fun(); NONO(); void NONO() *本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。 * FTLE *wf; wf=fopen(“out dat”,

7、“w”); fprintf(wf, “ f n”, fun(); fclose(wf); 国家二级 C语言机试(操作题)模拟试卷 51答案与解析 一、程序填空题 1 【正确答案】 (1)x (2)p (3)s 【试题解析】 函数 fun的功能是把形参 x的值放入一个新结点并插入到链表中,插入后各结点数据域的值仍保持递增有序。利用循环搜索链表,找到插入位置,将新结点插入到链表当中。 解题思路 第一空: “s=(SLIST*)malloc(sizeof(SLIST); ”显然 s是一个新结点,第一空处是给新结点的数据域赋值 x,因此第一空处应该是 “s-, data=x: ”。 第二空:循环 “w

8、hile(p!=NULL&xp-data)”是用来寻找插入位置,当链表没有结 束且 x仍然大于 p所指向的结点的数据时,就不断的向链表后面搜索。在循环体内,语句 “p=p一 next; ”是找到下一个结点的地址,变量 q用来保存当前结点的地址,因此第二空处应该是 “q=p; ”。 第三空: “s-next=p; ”将 s插入链表当中, s指向 p,此时 s结点已经指向需要插入位置的下一个节点,因此在需要插入 s结点的位置的上一个结点需要指向 s结点,故第三处应该为 “q一 next=s; ”。 二、程序修改题 2 【正确答案】 (1)t=t一 1 0 i;或 t一 =1 0 i;或 t一 =(

9、double)1 i; (2)return t; 【试题解析】 函数的功能是计算公式的值。 (1)第一个标识下的 “t=1 0-1 i; ”语句对题干中给出的多项式的求值,而根据题干中多项式的特点,多项式应该是 “t=t一 1 0 i=”。 (2)根据函数定义, fun函数应该具有返回值,第二个标识下的填空应该是“return t: ”返回多项式的值。 三、程序设计题 3 【正确答案】 float x0, x1=0 0 ; do x0=x1; x1=cos(x0); while(fabs(x0一 x1)0 000001); return x1; 【试题解析】 该程序功能是利用简单迭代方法求方程的一个实根。牛顿迭代法的求解思想是从一个初始值开始,逐步逼近所求方程的根。 其具体过程是:将初始值代入迭代公式,得到一个迭代输出值。再次迭代时,将上一次的迭代输出值当作本次的迭代输入。不断重复以上过程,直到满足题目要求为止。 牛顿迭代公式为: Xn+1=Xn一 f(x) f(x)。 其求解过程在题干中已经给出。

copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1