欢迎来到麦多课文档分享! | 帮助中心 海量文档,免费浏览,给你所需,享你所想!
麦多课文档分享
全部分类
  • 标准规范>
  • 教学课件>
  • 考试资料>
  • 办公文档>
  • 学术论文>
  • 行业资料>
  • 易语言源码>
  • ImageVerifierCode 换一换
    首页 麦多课文档分享 > 资源分类 > DOC文档下载
    分享到微信 分享到微博 分享到QQ空间

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

    • 资源ID:498440       资源大小:31.50KB        全文页数:6页
    • 资源格式: DOC        下载积分:2000积分
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    二维码
    微信扫一扫登录
    下载资源需要2000积分(如需开发票,请勿充值!)
    邮箱/手机:
    温馨提示:
    如需开发票,请勿充值!快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如需开发票,请勿充值!如填写123,账号就是123,密码也是123。
    支付方式: 支付宝扫码支付    微信扫码支付   
    验证码:   换一换

    加入VIP,交流精品资源
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

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

    1、国家二级 C语言机试(操作题)模拟试卷 485及答案与解析 一、程序填空题 1 函数 fun的功能是:将一副扑克牌编号为 1, 2, 3, , 53, 54,以某种特定的方式洗牌,这种方式是将这副牌分成两半,然后将它们交叉,并始终保持编号为 1的牌在最上方,如第一次这样洗牌后的结果为: 1, 28, 2, 29, , 53, 27, 54。两次洗牌后的结果为: 1, 41, 28, 15, 2, 42一一, 53, 40, 27, 14, 54。 程序的功能是:输出经过 n次这样洗牌后的结果。 请在程序的下画线处填入正确的内容,并把下画线删除,使程序得出正 确的结果。 注意:源程序存放在考生文

    2、件夹下的 BLANK1 C中。不得增行或删行,也不得更改程序的结构! 试题程序: #include stdio h void fun(int a55, int n) fint i, k; /*found*/ int 【 1】 55; for(i=0; i n; i+) for(k=1; k =27; k+) b2*k一 1=ak; /*found*/ b【 2】 *k=ak+27; for(k=1; k =54; k+) /*found*/ ak=【 3】 ; main() int m a55,i; for(i=1; i 55; i+)ai=i; printf( “请输入洗牌次数: “); s

    3、canf(“ d“, &m); fun (a, m) ; for (i = 1; i 55; i +) printf (“n“) ; 二、程序修改题 2 给定程序 MODI1 C中,函数 fun的功能是:判断输入的任何一个正整数 n,是否等于某个连续正整数序列之和。若是,则输出所有可能的序列,否则输出 “不能分解 ”。 例如:当输入 100时,输出: 100 =9+10+11+12+13+14+15+16 100 =18+19+20+21+22 请改正函数 fun中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main函数,不得增行或删行,也不得更改程序的结构。 试题程序: #inc

    4、lude stdio h void fun ( int n ) int j, b, c, m, f1ag=0; for(b=1; b =n/2; b+) /*found*/ n=m; c=b; while(m!=0&m =c) /*found*/ m=mc; c+ /*found*/ if(m!=0) printf(“ d=“, n); for(j=b; j c一 1; j+) printf(“ d+“, j); printf(“ dn“, j); f1ag=1; if(f1ag=0) printf(“不能分解 n“); main() int n; printi(“请输入一个整数: “); s

    5、canf(“ d“, &n); fun(n); 三、程序设计题 3 请编写函数 fun,其功能是:判断 t所指字符串中的字母是否由连续递增字母序列组成 (字符串长度大于等于 2)。例如字符串: uvwxyz满足要求;而字符串:uvxwyz不满足要求。 注意:部分源程序存放在 PROG1 C中,请勿改动主函数 main和其他函数中的任何内容,仅在函数 fun指定的部位填入所编写的若干语句 。 试题程序: #1nclucle stclio h #include string h void NONO(); int fun(char*t) main() char s26; printf(“请输入一个字

    6、母组成的字符串: “); gets(s); if(fun(s)print: f(“ s是由连续字母组成的字符串 *n“, s); else printf(“ s不是由连续字母组成的字符串 !n“, s); NONO(); void NONO() /*本函数用于打开文件,输入数据,调用函数,输出数据,关闭文件。 */ FILE*fp, *wf; int i; char s26, *p; fp; iopen(“c: testin dat“, “12“); wf=fopen(“c: testout dat“, “w“); for(i=0 ; i 10; i+) fgets(s, 26, fp); p

    7、=strchr(s, n); if(p)*p=0; if(fun(s)fprinti(wf, “ sn“, s+2); else fprintf(wf, “ sn“, strrev(s); fclose(fp); fclose(wf); 国家二级 C语言机试(操作题)模拟试卷 485答案与解析 一、程序填空题 1 【正确答案】 (1)b (2)2 (3)bk 【试题解析】 填空 1: for循环中使用了一个数组 b,用来临时存放交换位置后的扑克牌, C语言中变量需要先声明后使用,所以填空 (1)处需要声明一个数组 b。答案为 b。 填空 2:第二个 for循环是将数组 a中前一半元素(即 1一

    8、 27编号的扑克牌)放入数组 b的奇数位置,将数组 a中的后一半元素(即 28 54编号的扑克牌)放入数组 b的偶数位置,实现扑克牌的交叉洗牌。所以填空 (2)处是数组 b的起始值为2的偶数下标 2k,答案为 2。 填空 3:由于数组 b属于函数中的临时变量,所以将数组 a的元素交叉存储到数组b后,还需要将数组 b的元素依次赋值给数组 a,第三个 for循环实现的功能是将数组 b赋值给数组 a,所以填空 (3)处需要填入对应下标为 k的数组 b的元素,答案为 bk。 二、程序修改题 2 【正确答案】 (1)m=n; (2)m=m一 c; c+; (3)if(m=0) 【试题解析】 (1)每次循

    9、环,程序需要对 n执行减去连续的正整数序列来判断 n是否刚好为 0,即 n是否是连续的正整数序列之和,所以需要使用临时变量 m寄存 n的值,每次循环对 m执行减运算操作,不满足继续下一轮。另外,程序声明变量 m时,未初始化它的值,所以此处应该修改为: m=n。 (2)语法错误。 C语言中每个语句必须以分号结束,所以应修改为: m=m一 c;c+;。 (3)题目判断 n是否是连续的正整数序列之和,若是,则输出所有序列,程序中 m依次减去连续的正整数,当 m为 0时,表示 m(即 n)满足条件,再输出当前序列中的每个正整数,所以此 处判断条件反了,应修改为: if( m=0)。 三、程序设计题 3

    10、 【正确答案】 int fun(char*t) int fen=str1en(t); if(1en 2) return 0; char before_ch=t0; char current_ch; int f1ag=1 ; for(int i=1; ti!= 0; +i) current_ch=ti; if fbefore_ch!=cur rent_ch一 1) f1ag=0 ; break; before_ch=current_ch; return f1ag; 【试题解析】 函数 fun的功能是判断指针 t指向的字符串是否是由连续递增的字母构成,返回值为整数, 0代表不满足条件。根据题目要求,字符串长度必须大于等于 2,所以首先需要对 t指向的字符串进行长度判断,小于 2的字符串返回 0。接着需要对字符串中的连续字符,逐个进行比较。 C语言中字符变量可以当作整数使用,所以当前字符只有是前一个字符的 ASCII码 +1,才能说它们是连续递增字母序列,然后比较后一个字符与当前字符的 ASCII码,如果字符串中的 所有字符都满足条件,则返回 1;否则说明该字符串不满足要求,此时设置 flag=0,后面的字符也就不需要再比较了,跳出循环返回即可。


    注意事项

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




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

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

    收起
    展开