1、计算机三级网络技术机试(上机操作)模拟试卷 81及答案与解析 一、程序设计题 1 文件 IN DAT中存有 200个四位整型数,函数 ReadData()负责将 IN DAT中的数读到数组 inBuf中。请编写函数 findValue(),其功能是:把千位数字和十位数字重新组合成一个新的两位数 ab(新两位数的十位数字是原四位数的干位数字,新两位数的个位数字是原四位数的十位数字 ),以及把个位数和百位数组成另一个新的两位数 cd(新两位数的十位数字是原四位数的个位数字,新两位数的个位数字是原四位数的百位数字 ),新组成 的两个两位数 ab cd10且 abcd20且两个数均为偶数,同时两个新数
2、十位数字均不为零。求出满足条件的数,用 count记录下符合条件的数的个数并按照从大到小的顺序存入数组 outBuf中。函数 WriteData()负责将 outBuf中的数输出到文件 OuT DAT中并且在屏幕上显示出来。 注意;部分源程序已给出。 程序中已定义数组: inBuf200, outBuf200,已定义变量: count。 请勿改动主函数 main()、读函数 ReadData()和写函数 WriteData()的内容。 试题程序: #include #define NUM 200 int inBufNUM, outBufNUM, count=0; void ReadData()
3、; void WriteData(); void findValue() void main() int i; ReadData(); findValue(); I WriteData(); printf(“count= d n”, count); for(i=0; i=10 minus=20 1(ab 2+ cd 2)=0&d0!=0 d3!=0 outBufcount=inBufi; count+; for(i=0; icount-1; i+) 以下是将数据进行从大到小排序的程序 for(j=i+1; jcount; j+) if(outBufioutBufj) 如果第 i位比它后面的数小
4、 则将两者进行交换即将更大的值放到第 i位 temp=outBufi; outBufi=outBufj; outBufj=temp; 【试题解析】 本题主要考查数位分解及排序。 数位分解就是将 n位数上各个数位上的数值单独分离出来。解决此问题的方法是:将 n位教对 10求余可以将个 位上的数值分离出来。将这个 n位数除以 10以后得到一个 n-1位数,则此时 n位数原来的十位就变成了 n-1位数的个位,再将此n-1位数对 10求余便可得到原 n位数的十位。依此类推,按照同样的方法便可将n位数各个数位上的数值分离出来。 程序步骤: 将数值送入 temp中。 由 temp 10得到个位教; (temp 10)10得到十位教 如此可得到各位上的数值。 按照题目所给的条件选出数据。 对选出的数据进行排序,排序的思想是 (以从小到大为例 ):将当前数据与其后的各个数据相比较,如果当前的数据比其后的数据大,则 将两数据进行交换,从而使得前面的数据小于后面的数据。达到从小到大排序的目的。