1.设计一个程序,从in.txt读入数据,对每一行的数字都单独按从大到小的顺序排序,将结果输出到out.txt。
每一行的数字第一个字符是数字标志,每个数字之间用空格隔开。
in.txt:
3 12 -20 49
4 11 21 -49 90
out.txt:
3 -20 12 49
4 -49 11 21 90
#include<stdio.h>
#include<stdlib.h>
void sort(int *data,int len);
void save(FILE *p2,int *data,int len);
int main() {
FILE *p1,*p2;
int data[100],i=0;
p1 = fopen("E:\\in.txt","r");
if(!p1) {
printf("文件不存在无法打开");
exit(0);
}
while(!feof(p1)) {
fscanf(p1,"%d",&data[i++]);
if(fgetc(p1) == '\n') {//读到每一行末尾
save(p2,data,i);//将这一行数据复制另外一个文件中
i=0;
}
}
save(p2,data,i);
fclose(p1);
}
void save(FILE *p2,int *data,int len) {//将每一行数据保存到out.txt中
sort(data,len);
p2 = fopen("E:\\out.txt","a+w");
if(!p2) {
printf("文件不存在");
}
for(int i=0; i<len; i++) {
fprintf(p2,"%d ",data[i]);
}
fputc('\n',p2);//换行
fclose(p2);
}
void sort(int *data,int len) {//对每一行的数据进行排序
for(int i=0; i<len-1; i++) {
for(int j=0; j<len-1-i; j++) {
if(data[j] > data[j+1]) {
int t = data[j];
data[j] = data[j+1];
data[j+1] = t;
}
}
}
}