【项目4-工资的排序】
从文件salary.txt中读入工人的工资(不超过500人),全部增加20%(好事),然后对工资数据进行排序,将排序后的结果保存到文件ordered_salary.txt中。
做完打开文件看看结果,玩这么多数据于股掌之间,相信你会有成就感的。
[参考解答]
#include <stdio.h>
#include <stdlib.h>
int main()
{
double salary[500];
FILE *fpin, *fpout;
fpin=fopen("salary.txt","r");
if(fpin==NULL)
{
printf("salary file open error!\n");
exit(1);
}
fpout=fopen("ordered_salary.txt","w");
if(fpout==NULL)
{
printf("cannot write to file!\n");
exit(1);
}
int n=0;
while(fscanf(fpin, "%lf",&salary[n])!=EOF) //当读取成功……
{
salary[n]*=1.2;
n++;
}
fclose(fpin); //读入完毕要关闭文件
//共有n名职工,排序
int i, j;
double t; //用于交换的中间变量,也应该是double型
for (i=0; i<n-1; i++)
for(j=0; j<n-i-1; j++)
if (salary[j]>salary[j+1])
{
t=salary[j];
salary[j]=salary[j+1];
salary[j+1]=t;
}
for(i=0; i<n; i++) //输出排序后结果
fprintf(fpout, "%.2f\n", salary[i]);
printf("thanks, byebye!\n");
fclose(fpout);
return 0;
}