094题 在文件中有200个正整数,且每个数均在1000至9999之间。函数ReadDat()读取这200个数存放到数组aa中。请编制函数jsSort(),其函数的功能是:要求按每个数的后三位的大小进行降序排列,然后取出满足此条件的前10个数依次存入数组b中,如果后三位的数值相等,则按原先的数值进行升序排列。最后调用函数WriteDat()把结果bb输出到文件out.dat中。
例:处理前 9012 5099 6012 7025 8088
    处理后 5099 8088 7025 6012 9012
部分源程序已给出。
  请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。
#include<stdio.h>
#include<string.h>
#include<conio.h>

int aa[200],bb[10];

void jsSort()
{   int i,j,n,s;
     n=200;
   for(i=0;i<n-1;i++)
    for(j=i+1;j<n;j++)
       {
if(aa[i]%1000<aa[j]%1000)
           {s=aa[i];
                 aa[i]=aa[j];
                            aa[j]=s;
          }
        
else if(aa[i]%1000==aa[j]%1000)
               if(aa[i]>aa[j])
               {s=aa[i];
                     aa[i]=aa[j];
                                aa[j]=s;
                 }
   for(n=0;n<10;n++)
       bb[n]=aa[n];

}

void main()
{
readDat();
jsSort();
writeDat();
}

readDat()
{
FILE *in;
int i;

in=fopen(\ in.dat\ ,\ r\ );
for(i=0; i<200; i++) fscanf(in,\ %d\ ,&aa[i]);
fclose(in);
}

writeDat()
{
FILE *out;
int i;

out=fopen(\ out.dat\ ,\ w\ );
clrscr();
for(i=0; i<10; i++){
printf(\ i=%d,%d\\n\ ,i+1,bb[i]);
fprintf(out,\ %d\\n\ ,bb[i]);
}
fclose(out);
}

返回南开百题目录

www.163164.cn 联系QQ:3149886