一直以为写法和c++的sort差不多呢,没想到他的自定义函数部分真的不一样,想了下c不是没有泛型嘛,所以不能按照c++那种写法啊,然后也就接受了这种c的写法了,确实挺麻烦的,这个代码不针对某一个题,就当作c语言下的qsort函数的结构体变量大小排序的自定义模板了
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
typedef struct node{
char name[20];
char gender[20];
int old,num;
}node;
int cmp(const void*a,const void *b){
return((node*)a)->num>((node*)b)->num?1:-1;
}
int main(void){
int n;
int m=0;
scanf("%d",&n);
node p[100];
for(int i=0;i<n;i++){
scanf("%s%s%d%d",&p[i].name,&p[i].gender,&p[i].old,&p[i].num);
}
qsort(p,n,sizeof(p[0]),cmp);
for(int i=0;i<n;i++)
printf("%s %s %d %d\n",p[i].name,p[i].gender,p[i].old,p[i].num);
return 0;
}