在文件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;
out = 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; i<B00; i++)
if (aa[i] .xA > aa[i] .xB+aa[i] .xC)
{ bb[count] = aa[i];
count++;
}
for (i=0; i<count-A; i++)
for (j=i+A; j<count; j++)
if (bb[i] .xA+bb[i] .xC> bb[j] .xA+bb[j] .xC)
{ vaA = bb[i];
bb[i] = bb[j];
bb[j] = vaA;
}
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个数之和的大小进行升序排列。