#include<stdio.h>
#include<stdlib.h>
typedef struct //这里有修改
{
float a;
float b;
}point;
void sort(point nuage[],int n) //坐标排序的函数
{
int i,j;
float x,y;
for(i=0;i<n-1;i++){ // Bubble Sort comparer avec n-1
for(j=0;j<n-1-i;j++){
if (nuage[j].a>nuage[j+1].a){
x=nuage[j].a;y=nuage[j].b;
nuage[j].a=nuage[j+1].a;nuage[j].b=nuage[j+1].b;
nuage[j+1].a=x;nuage[j+1].b=y;
}else if(nuage[j].a==nuage[j+1].a && nuage[j].b>nuage[j+1].b){
x=nuage[j].a;y=nuage[j].b;
nuage[j].a=nuage[j+1].a;nuage[j].b=nuage[j+1].b;
nuage[j+1].a=x;nuage[j+1].b=y;
}}}
printf("-----------sort----------\n");
for (i=0;i<n;i++)
{printf(" %f %f \n",nuage[i].a,nuage[i].b);}
}
void nuage() //从文件中读入数据的函数
{
int i,num;
char buf[256]; //读入一行的缓冲区
FILE *f;
point *pnuage; //malloc分配内存的地址
f=fopen("data.txt","r");
if(f==NULL) {
printf("打开文件失败.\n");
return;
}
fgets(buf,256,f);
if(sscanf(buf,"%d",&num)!=1){ //第一行 坐标数量
printf("文件格式错误.\n");
return;
}
//point nuage[num]; //如果是C99以后是可以这样定义的
pnuage=(point *)malloc(sizeof(point)*num); //分配num个结构保存坐标
//读入num个坐标
for(i=0;i<num;i++){
fgets(buf,256,f);
if(sscanf(buf,"%f%f",&pnuage[i].a,&pnuage[i].b)!=2){
printf("文件格式错误.\n");
return;
}
}
sort(pnuage,num); //最后再排序
fclose(f);
free(pnuage); //释放malloc分配的内存
}
int main(){
nuage();
return 0;
}
|