在文件IN.dat中有200组数据,每组有3个数,每个数均是三位数。函数Rdata()读取这 200组数据存放到结构数组aa中,请编写函数greatSort(),其功能是:要求在200组数据中找出条件为每组中的第1个数大于第2个数加第3个数的和,其中满足条

admin2010-09-05  29

问题 在文件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. x1, &aa .x2, &aa .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.x1,
bb.x2, bb.x3, bb.x1 + bb. x3);
      fprintf (out, "%d  %d  %d\n", bb .x1, bb .x2,
bb .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<200; i++) if (aa[i] .x1 > aa[i] .x2+aa[i] .x3) { bb[count] = aa[i]; count++; } for (i=0; i<count-1; i++) for (j=i+1; j<count; 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个数之和的大小进行升序排列。

解析
转载请注明原文地址:https://kaotiyun.com/show/euvZ777K
0

最新回复(0)