对三维数组进行排序,x相等时比较y的大小,y相等时比较z的大小,用到qsort函数。

来源:互联网 发布:java输入输出学生成绩 编辑:程序博客网 时间:2024/06/10 20:51
#include<stdio.h>
#include<stdlib.h>
struct str
{
int x;
int y;
int z;
}a[502];
int cmp(const void *p,const void *q)
{
str *c=(str *)p;
str *d=(str *)q;
if(c->x!=d->x) 
return c->x-d->x;
else if(c->y!=d->y)
return c->y-d->y;
else  
return c->z-d->z;
}
int main()
{
int n, i, j, k, t;
 scanf("%d",&n);
for(i=0;i<n;i++)
 scanf("%d %d %d",&a[i].x,&a[i].y,&a[i].z);
qsort(a,n,sizeof(a[0]),cmp);
for(i=0;i<n;i++)
printf("%d %d %d\n",a[i].x,a[i].y,a[i].z);
return 0;
}


}
原创粉丝点击