C语言统计排序

已知数据文件 IN.DAT 中存有 200 个四位数,并已调用读函数 readDat()把这些数存入数组 a 中,请编制一函数 jsVal(),其功能是:依次从数组 a 中取出一个四位数,如果该四位数 连续小于该四位数以后的五个数且该数是偶数(该四位数以后不满五个数,则不统计),则统计出满足此条件的个数 cnt 并把这些四位数按从小到大的顺序存入数组 b 中,后调用写 函数 writeDat( )把结果 cnt 以及数组 b 中符合条件的四位数输出到 OUT.DAT 文件中。
#include <stdio.h>

#define MAX 200

int a[MAX], b[MAX], cnt = 0 ;

void jsVal()

{int i,j,flag;

for(i=0;i<MAX-5;i++)

{for(j=i+1;j<=i+5;j++)

if(a[i]<a[j]&&a[i]%2==0) flag=1;

else { flag=0; break;}

if(flag==1) b[cnt++]=a[i];

}

for(i=0;i<cnt-1;i++)

for(j=i+1;j<cnt;j++)

if(b[i]>b[j]) {flag=b[i];b[i]=b[j];b[j]=flag;}

}

void readDat()

{

int i ;

FILE *fp ;

fp = fopen(“in.dat”, “r”) ;

for(i = 0 ; i < MAX ; i++) fscanf(fp, “%d”, &a[i]) ;

fclose(fp) ;

}

void main()

{

int i ;

readDat() ;

jsVal() ;

printf(“满足条件的数=%d\n”, cnt) ;

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

printf("%d “, b[i]) ; printf(”\n") ;

writeDat() ;

}

writeDat()

{

FILE *fp ;

int i ;

fp = fopen(“out.dat”, “w”) ;

fprintf(fp, “%d\n”, cnt) ;

for(i = 0 ; i < cnt ; i++) fprintf(fp, “%d\n”, b[i]);

fclose(fp) ;

}

发布了239 篇原创文章 · 获赞 3 · 访问量 3163

猜你喜欢

转载自blog.csdn.net/it_xiangqiang/article/details/105164220
今日推荐