有道c语言编程题看了答案还不是太理解,高手帮忙解释下~

那位高手帮忙把答案的每句话都解释一下啊,功能是什么~谢谢~~~~~~~
092题 在文件in.dat中有200组数据,每组有3个数,每个数均是三位数。函数ReadDat()读取这200组数据存放到结构数组aa中,请编制函数jsSort(),其函数的功能是:要求在200组数据中找出条件为每组中的第二个数大于第一个数加第三个数的之和,其中满足条件的个数作为函数jsSort() 的返回值,同时把满足条件的数据存入结构数组bb中,再对bb中的数据按照每组数据的第二个数加第三个之和的大小进行降序排列(第二个数加第三个数的和均不相等),排序后的结果仍重新存入结构数组bb中,最后调用函数WriteDat()把结果bb输出到文件out.dat中。
部分源程序已给出。
请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。
#include<stdio.h>
#include<string.h>
#include<conio.h>
typedef struct{
int x1,x2,x3;
}data;
data aa[200],bb[200];
int jsSort()
{int i,j,k=0;
DATA swap;
for(i=0;i<200;i++)
if(aa[i].x2>(aa[i].x1+aa[i].x3))
bb[k++]=aa[i];
for(i=0;i<k-1;i++)
for(j=i+1;j<k;j++)
if((bb[i].x2+bb[i].x3)<(bb[j].x2+bb[j].x3))
{
swap=bb[i];
bb[i]=bb[j];
bb[j]=swap;
}
return k;

}
void main()
{
int count;
readDat();
count=jsSort(); /*返回满足条件的个数*/
writeDat(count);
}
readDat()
{
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);
}
writeDat(int count)
{
FILE *out;
int i;
out=fopen(\ out.dat\ ,\ w\ );
clrscr();
for(i=0; i<10; i++){
printf(\ %d,%d,%d 第二个数+第三个数=%d\\n\ ,bb[i].x1,bb[i].x2,bb[i].x3,bb[i].x2+bb[i].x3);
fprintf(out,\ %d%d%d\\n\ ,bb[i].x1,bb[i].x2,bb[i].x3);
}
fclose(out);
}

像是南开100题上的问题,你能不能把问题说的再清楚一点,这个题倒是很容易,但是不知道你理解到什么程度,具体是哪个地方不清楚呢?

以下是我简单写的注释,不知道你能不能看明白。。。
欢迎到我的空间留言。。。
#include<stdio.h>
#include<string.h>
#include<conio.h>

typedef struct{
int x1,x2,x3;
}data; //定义结构体并声明为data型,x1,x2,x3分别为每组数中的三个数字

data aa[200],bb[200]; //定义data型数组aa[],bb[]

int jsSort()
{
int i,j,k=0;
DATA swap; //定义data型变量
for(i=0;i<200;i++) //
if(aa[i].x2>(aa[i].x1+aa[i].x3)) //如果满足第2个数大于第1个数加第3个数
bb[k++]=aa[i]; //则将该类型数组aa[i]存入bb[]数组中
for(i=0;i<k-1;i++) //排序算法
for(j=i+1;j<k;j++) //
if((bb[i].x2+bb[i].x3)<(bb[j].x2+bb[j].x3)) //如果满足条件,进入交换算法中
{
swap=bb[i]; //
bb[i]=bb[j]; //
bb[j]=swap; //这三条语句是一个交换算法,交换当满足判断条件时,将数组
}
return k; //返回k值
}

void main() //主函数
{
int count; //定义变量count,计数器
readDat(); //调用读函数
count=jsSort(); //返回满足条件的个数
writeDat(count); //调用写函数
}

readDat() //读函数
{
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);
}

writeDat(int count) //写函数
{
FILE *out;
int i;
out=fopen(\ out.dat\ ,\ w\ );
clrscr();
for(i=0; i<10; i++){
printf(\ %d,%d,%d 第二个数+第三个数=%d\\n\ ,bb[i].x1,bb[i].x2,bb[i].x3,bb[i].x2+bb[i].x3);
fprintf(out,\ %d%d%d\\n\ ,bb[i].x1,bb[i].x2,bb[i].x3);
}
fclose(out);
}
温馨提示:答案为网友推荐,仅供参考
相似回答