我想在我的程序中使用qsort()函数。
我想用字符串对这个结构进行排序。
我刚刚指点。
我搜索了互联网,但我没有得到它。
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int cmpstr(const void* a, const void* b)
{
const char* aa = *(const char**)a;
const char* bb = *(const char**)b;
return strcmp(aa,bb);
}
typedef struct
{ int x;
char a[10];
}alex;
int main()
{
alex vd[10];
int i;
//vd=malloc(sizeof(struct alex)*2);
strcpy(vd[0].a,"dinamitte");
strcpy(vd[1].a,"alex");
printf("Before : \n");
for(i=0;i<=1;i++)
printf("%s ",vd[i].a);
//qsort(v,1,sizeof (v) ,myCompare);
int n=2;
//qsort(v, 2, sizeof (char *), cstring_cmp);
qsort(vd,n ,sizeof(alex),cmpstr);
//qsort()
printf("\nAfter : \n");
for(i=0;i<=1;i++)
printf("%s \n",vd[i]);
return 0;
}
编译完成后,它会在屏幕上写'dinamitte'和'alex',然后是一些奇怪的字符。
答案 0 :(得分:0)
像这样解决:
typedef struct {
int x;
char a[10];
} alex;
int cmpstr(const void* a, const void* b){
const alex *aa = a;
const alex *bb = b;
return strcmp(aa->a, bb->a);
}
同样printf("%s \n",vd[i]);
错字为printf("%s \n",vd[i].a);