早教吧 育儿知识 作业答案 考试题库 百科 知识分享
早教吧考试题库频道 --> 计算机类考试 -->计算机三级 -->

在文件IN.dat中有200组数据,每组有3个数,每个数均是三位数。函数Rdata()读取这 200组数据存放到结

题目

在文件IN.dat中有200组数据,每组有3个数,每个数均是三位数。函数Rdata()读取这 200组数据存放到结构数组aa中,请编写函数greatSort(),其功能是:要求在200组数据中找出条件为每组中的第1个数大于第2个数加第3个数的和,其中满足条件的组数作为函数 greatSort()的返回值,同时把满足条件的数据存入结构数组bb中,再对bb中的数据按照每组数据的第1个数加第3个数之和的大小进行升序排列(第1个数加第3个数的和均不相等),排序后的结果仍重新存入结构数组bb中。最后调用函数Wdata(),把结果bb输出到OUT.dat文件中。

注意:部分源程序已经给出。请勿改动主函数main()、读数据函数Rdata()和输出数据函数Wdata()的内容。

include <stdio. h>

include <string.h>

include <conio. h>

typedef struct

{ int x1, x2, x3;

} data;

data aa[200], bb[200];

int greatSort ()

{

}

void Rdata ()

{ FILE *in;

int i;

in = fopen("IN.dat", "r");

for (i=0; i<200; i++)

fscanf (in, "%d %d %d", &aa[i]. x1, &aa[i] .x2, &aa[i] .x3);

fclose (in);

}

void Wdata(int count)

{ FILE *out;

int i;

ut = fopen("OUT.dat", "w");

for (i=0; i<count; i++)

{ printf("%d,%d,%d 第一个数+第三个数=%d\n", bb[i].x1,

bb[i].x2, bb[i].x3, bb[i].x1 + bb[i]. x3);

fprintf (out, "%d %d %d\n", bb[i] .x1, bb[i] .x2,

bb[i] .x3);

}

fclose (out);

}

void main ()

{ int count;

Rdata ( );

count = greatSort() ;/* 返回满足条件的个数 */

Wdata (count);

}

参考答案
正确答案:int greatSort() { int i j count = 0; data val; for (i=0; i200; i++) if (aa[i] .x1 > aa[i] .x2+aa[i] .x3) { bb[count] = aa[i]; count++; } for (i=0; icount-1; i++) for (j=i+1; jcount; j++) if (bb[i] .x1+bb[i] .x3> bb[j] .x1+bb[j] .x3) { va1 = bb[i]; bb[i] = bb[j]; bb[j] = va1; } return count; } [解题思路] 在for循环语句中自变量i从0递增到200判断每组中的第1个数大于第2个数加第3个数之和即表达式aa[i]. x1>aa[i]. x2+aa[i]. x3是否成立如果表达式成立即把aa [i] 赋给数组变量bb同时计数变量count自加。最后用两重循环对数组bb中的数据按照每组数据的第2个数加第3个数之和的大小进行升序排列。
int greatSort() { int i, j, count = 0; data val; for (i=0; i200; i++) if (aa[i] .x1 > aa[i] .x2+aa[i] .x3) { bb[count] = aa[i]; count++; } for (i=0; icount-1; i++) for (j=i+1; jcount; j++) if (bb[i] .x1+bb[i] .x3> bb[j] .x1+bb[j] .x3) { va1 = bb[i]; bb[i] = bb[j]; bb[j] = va1; } return count; } [解题思路] 在for循环语句中,自变量i从0递增到200,判断每组中的第1个数大于第2个数加第3个数之和即表达式aa[i]. x1>aa[i]. x2+aa[i]. x3是否成立,如果表达式成立,即把aa [i] 赋给数组变量bb,同时计数变量count自加。最后用两重循环对数组bb中的数据按照每组数据的第2个数加第3个数之和的大小进行升序排列。