[计算机类试卷]国家三级(网络技术)机试模拟试卷204及答案与解析.doc
-
资源ID:495716
资源大小:27KB
全文页数:4页
- 资源格式: DOC
下载积分:2000积分
快捷下载

账号登录下载
微信登录下载
下载资源需要2000积分(如需开发票,请勿充值!)
友情提示
2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
|
[计算机类试卷]国家三级(网络技术)机试模拟试卷204及答案与解析.doc
1、国家三级(网络技术)机试模拟试卷 204及答案与解析 一、程序设计题 1 文件 IN DAT中存有 200个四位整型数,函数 ReadData()负责将 IN DAT中的数读到数组 inBuf中。请编写函数 findValue(),其功能是;求出各数位上的数字均是 0或 2或 4或 6或 8的数,按照从大到小的顺序存人数组 outBuf中,并用count 记录下符合条件的数的个数。函数 WriteData()负责将 outBuf中的数输出到文件 OUT DAT中并且在屏幕上显示出来。 注意;部分源程序已给出。 程序中已定 义数组; inBuf200, outBuf200,已定义变量; coun
2、t。 请勿改动主函数 main()、读函数 ReadData()和写函数 WriteData()的内容。 试题程序; #include #define NUM 200 int inBufNUM, outBufNUM, count=0; void ReadData(); void WriteData(); void findValue() void main() int i; ReadData(); findValue(); WriteData(); printf(“count= d n“, count); for(i=0; i count; i+) printf(“outBuf d= d n“
3、, i, outBuf i); void ReadData() FILE*fp; int i; fp=fopen(“IN DAT“, “r“); for(i=0; iNUM; i+) fscanf(fp, “ d, “, &inBufi); fclose(fp); Void WriteData() FILE*fp; int i; fp=fopen(“OUT DAT“, “w“); fprintf(fp, “count= d n“, count); for(i=0; icount; i+) fprintf(fp, “ d, n“, outBufi); fclose(fp); 国家三级(网络技术)
4、机试模拟试卷 204答案与解析 一、程序设计题 1 【正确答案】 void findValue() int i, j, k, d4, temp; for(i=0; iNUM; i+) for(j=0; j4; j+) temp=inBufi; 将要进行分解的数据存入 temp中 for(k=0; kj; k+)temp=temp 10; 求第 j位的值 d3-j=temp 10; 先将 temp除以 10的 j次方,再对其求余即可 if(d0 2=0&d1 2=0&d2 2=0&d3 2=0) outBufcount=inBufi; count+; for(i=0; icount-1; i+)
5、 对数据按从大到小的顺序进行排序 for(j=i+1; jcount; j+) if(outBufioutBufj) 如果第 i位比它后面的数小,则将两者进行交换 temp=outBufi; outBufi=outBufj; outBufj=temp; 【试题解析】 本题主要考查数位分解及排序。数位分解就是将 n 位数上各个数位上的数值单独分离出来。解决此问题的方法是;将 n位数对 10求余可以将个位上的数值分离出来。将这个 n 位数除以 10以后得到一个 n-1位数,则此时 n位数原来的 10位就变成了 n-1位数的个位,再将此 n-1位数对 1 0求余便可得到原 n位数的 10位。依此类推,按照同样的方法便可将 n 位数各个位上的数值分离出来。程序步骤; 1将数值送入 temp 中。 2由 temp 10得到个位数; (temp 10)10得到十位数 如此可得到各位上的数值。 3按照题目所给的条件选出数据。4对选出的数据进行排序,排序的思想是 (以从小到大为例 );将当前数据与其后的各个数据相比较,如果当前的数据比其后的数据大,则将两数据进行交换,从而使得前面的数据小于后面的数据,达到从小到大排序的目的。