qsort反转字符串的顺序

时间:2013-08-14 06:49:02

标签: c arrays string qsort

我正在尝试使用qsort按字母顺序对字符串进行排序。目前它似乎正在颠倒我的字符串的顺序。

printf("unsorted %s\n", string);
qsort(string, strlen(string), sizeof(char), compare);
printf("sorted %s\n", string);

string是字符串“ACBD”。第二个printf显示为“DBCA”。我的比较功能是,

compare(const void *a1, const void *b1){
     const int *a2 = a1;
     const int *b2 = b1;

     if(*a2 == *b2){
         return 0;
     }
     else{
         if(*a2 < *b2){
             return -1;
         }
         else{
             return 1;
         }
    }
}

我确定我做的事情非常愚蠢,但任何帮助都表示赞赏。

编辑:字符串声明为char string[1000]

1 个答案:

答案 0 :(得分:4)

您想要进行字符比较,但实际上是在进行整数比较(sizeof int&gt; sizeof char)。

修复如下:

 char *a2 = a1;
 char *b2 = b1;