1、三级数据库技术机试-208 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.在文件 IN.dat中有 200组数据,每组有 3个数,每个数均是三位数。函数 Rdata()读取这 200 组数据存放到结构数组 aa中,请编写函数 greatSort(),其功能是:要求在 200组数据中找出条件为每组中的第 1个数大于第 2个数加第 3个数的和,其中满足条件的组数作为函数 greatSort()的返回值,同时把满足条件的数据存入结构数组 bb中,再对 bb中的数据按照每组数据的第 1个数加第 3个数之和的大小进行升序排列(第 1个数加第 3个数
2、的和均不相等),排序后的结果仍重新存入结构数组 bb中。最后调用函数Wdata(),把结果 bb输出到 OUT.dat文件中。注意:部分源程序已经给出。请勿改动主函数 main()、读数据函数 Rdata()和输出数据函数 Wdata()的内容。#include stdio. h#include string.h#include conio. htypedef structint x1, x2, x3;data;data aa200, bb200;int greatSort ()void Rdata ()FILE *in;int i;in = fopen(“IN.dat“, “r“);for
3、(i=0; i200; i+)fscanf (in, “%d %d %d“, fclose (in);void Wdata(int count)FILE *out;int i;out = fopen(“OUT.dat“, “w“);for (i=0; icount; i+)printf(“%d,%d,%d 第一个数+第三个数=%d/n“, bbi.x1,bbi.x2, bbi.x3, bbi.x1 + bbi. x3);fprintf (out, “%d %d %d/n“, bbi .x1, bbi .x2,bbi .x3);fclose (out);void main () int coun
4、t;Rdata ( );count = greatSort() ;/* 返回满足条件的个数 */Wdata (count); (分数:100.00)_三级数据库技术机试-208 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.在文件 IN.dat中有 200组数据,每组有 3个数,每个数均是三位数。函数 Rdata()读取这 200 组数据存放到结构数组 aa中,请编写函数 greatSort(),其功能是:要求在 200组数据中找出条件为每组中的第 1个数大于第 2个数加第 3个数的和,其中满足条件的组数作为函数 greatSort()的返
5、回值,同时把满足条件的数据存入结构数组 bb中,再对 bb中的数据按照每组数据的第 1个数加第 3个数之和的大小进行升序排列(第 1个数加第 3个数的和均不相等),排序后的结果仍重新存入结构数组 bb中。最后调用函数Wdata(),把结果 bb输出到 OUT.dat文件中。注意:部分源程序已经给出。请勿改动主函数 main()、读数据函数 Rdata()和输出数据函数 Wdata()的内容。#include stdio. h#include string.h#include conio. htypedef structint x1, x2, x3;data;data aa200, bb200;
6、int greatSort ()void Rdata ()FILE *in;int i;in = fopen(“IN.dat“, “r“);for (i=0; i200; i+)fscanf (in, “%d %d %d“, fclose (in);void Wdata(int count)FILE *out;int i;out = fopen(“OUT.dat“, “w“);for (i=0; icount; i+)printf(“%d,%d,%d 第一个数+第三个数=%d/n“, bbi.x1,bbi.x2, bbi.x3, bbi.x1 + bbi. x3);fprintf (out,
7、“%d %d %d/n“, bbi .x1, bbi .x2,bbi .x3);fclose (out);void main () int count;Rdata ( );count = greatSort() ;/* 返回满足条件的个数 */Wdata (count); (分数:100.00)_正确答案:(int greatSort() int i, j, count = 0;data val;for (i=0; i200; i+)if (aai .x1 aai .x2+aai .x3) bbcount = aai;count+;for (i=0; icount-1; i+)for (j=i+1; jcount; j+)if (bbi .x1+bbi .x3 bbj .x1+bbj .x3) va1 = bbi;bbi = bbj;bbj = va1;return count;)解析:解题思路 在 for循环语句中,自变量 i从 0递增到 200,判断每组中的第 1个数大于第 2个数加第 3个数之和即表达式 aai. x1aai. x2+aai. x3 是否成立,如果表达式成立,即把 aa i 赋给数组变量 bb,同时计数变量 count自加。最后用两重循环对数组 bb中的数据按照每组数据的第 2个数加第 3个数之和的大小进行升序排列。