1、计算机三级网络技术机试(上机操作)模拟试卷 67及答案与解析 一、程序设计题 1 文件 IN DAT中存有 200个四位整型数。函数 readData()负责将 IN DAT中的数读到数组 inBuf中。请编写函数 findValue(),其功能是 t把个位数字和千位数字重新组合成一个新的两位数 ab(新两位数的十位数字是原四位数的个位数字。新两位数的个位数字是原四位数的千位数字 ),以及把百位数和十位数组成另一个新的两位数 ed(新两位数的十位数字是原四位数的百位数字,新两位数的个位数字是原四位数的十位数字 )。新组成 的两个两位数必须有一个是奇数,另一个为偶数且两个两位数中至少有一个数能被
2、 17整除,同时两个新数的十位数字均不为 0。求出满足条件的数,用 count记录下符合条件的数的个数。并按照从大到小的顺序存入数组 outBuf中。函数 writeData()负责将 outBuf中的数输出到文件 OUT DAT中,并且在屏幕上显示出来。 程序中已定义数组: inBuf200, outBuf200,已定义变量; count。 请勿改动主函数 main()、读函数 readData()和写函数 writeData()的内容。 试题程序: #include #define NUM 200 int inBufNUM, outBufNUM, COUnt=0; void readDat
3、a(); void writeData(); void findValue() void main() int i; readData(); findValue(); writeData(); printf(“count= d n”, count); for(i=0; icount; i+) printf(“outBuf d= d n”, i, outBufi); void readData() FILE*fp; int i; fp=fopen(“IN DAT”, “r”); for(i=0; iNUM; i+) fseanf(fp, “ d, ”, inBufi); felose(fp);
4、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); felose(fp); 计算机三级网络技术机试(上机操作)模拟试卷 67答案与解析 一、程序设计题 1 【正确答案】 void findValue() int i, j, k, d4, temp, ab, cd for(i=0; iNUM; i+) for(j=0; j4; j+) temp=inBufi; 将
5、要进行分解的数据存入 temp中 for(k=0; kj; k+) temp=temp 10;求第 j位的值时 d3-i=temp 10; 先将 temp除以 10的 j次方,再对其求余 即可 ab=d3*10+d0; 将个位数字和千位数字组成新数 ab cd=d1*10+d2; 将百位数字和十位数字组成新数 cd *如果两新数中有一个奇数,另一个为偶数且 至少有一个能被 17整除 同时两新数的十位数均不为 0* if(ab 2=0 cd 2=0) (ab 2!= cd 2) (ab 17*cd 17=0) d3! =0 d1!=0) outBufcount=inBufi; 则将满足条件的数存
6、入 outBuf中 count+; 并使计数器加 1 for(i=0; icount-1; i+) 以下是对数据进行从大到小的排序 for(j=i+1; jcount; j+) if(outBufioutBufj) temp=outBufi; outBufi=outBufj; outBufj=temp; 【试题解析】 本题考查的主要是数位分解及排序。数位分解就是将 n位数各个位上的数值单独分离出来,将此 n位数时 10求余可以将个位上的数值分离出来;将此 n位数除以 10以后得到一个 n-1位数,则此时 n位数原来的十位就变成了 n-1位数的个位,再将此 n一 1位数对 10求余便可得到原 n位数的十位。依此类推,便可将 n位数各个位上的数值分离出采。 程序基本步骤是: 将数值送入 temp中。 由 temp 10得到个位数; (temp10) 10得到十位教,依此类推可得到各位上的数 值。 按照题目所给的条件筛选出数据。 对选出的数据进行排序。