1大于2加3
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
在文件in71.dat中有200组数据,每组有3个数,每个数均为3位数。函数readDat()是读取这200组数存放到结构数组aa中。请编制函数jsSort(),其函数的功能是:要求在200组数据中找出条件为每组数据中的第一个数大于第二个数加第三个数之和,其中满足条件的个数作为函数jsSort()的返回值,同时把满足条件的数据存入结构数组bb中,再对bb中的数按照每组数据的第一个数加第三个数之和的大小进行升序排列(第一个数加第三个数的和均不相等),排序后的结果仍重新存入结构数组bb中。最后调用函数writeDat()把结果bb 输出到文件out71.dat。
注意:部分源程序已给出。
请勿改动主函数main( )、读函数readDat( )和写函数writeDat( )的内容。
试题程序
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
typedef struct
{
int x1,x2,x3;
} Data;
Data aa[200],bb[200];
void readDat();
void writeDat();
int jsSort()
{
int i,j; /*定义循环控制变量*/
int cnt=0; /*定义计数器变量*/
Data temp; /*数据交换时的暂存变量,这里是一个Data类型的结构体变量*/
for(i=0;i<200;i++)
if(aa[i].x1>aa[i].x2+aa[i].x3) /*如果每组数据中的第一个数大于第二个数加第三个数之和*/
{
bb[cnt]=aa[i]; /*把满足条件的数据存入结构数组bb中*/
cnt++; /*同时统计满足条件的数据的个数*/
}
for(i=0;i<cnt-1;i++) /*对数组bb中的数按照每组数据的第一个数加第三个数之和的大小进行升序排列*/
for(j=i+1;j<cnt;j++)
if(bb[i].x1+bb[i].x3>bb[j].x1+bb[j].x3)
{
temp=bb[i];
bb[i]=bb[j];
bb[j]=temp;
}
return cnt; /*返回满足条件的数据的组数*/
}
void main()
{
int count;
readDat();
count=jsSort();
writeDat(count);
}
void readDat()
{
FILE *in;
int i;
in=fopen("in71.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 writeDat(int count)
{
FILE *out;
int i;
system("CLS");
out=fopen("out71.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);
}