要對C語言中的字符數組進行排序,可以使用標準庫函數qsort()
。首先需要包含頭文件<stdlib.h>
,然后定義一個比較函數來指定排序規則。
下面是一個示例程序,對字符數組進行排序:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 比較函數,用于指定排序規則
int compare(const void *a, const void *b) {
return *(char*)a - *(char*)b;
}
int main() {
char arr[] = {'d', 'c', 'a', 'b', 'e'};
int n = sizeof(arr) / sizeof(arr[0]);
printf("Before sorting: ");
for (int i = 0; i < n; i++) {
printf("%c ", arr[i]);
}
printf("\n");
qsort(arr, n, sizeof(char), compare);
printf("After sorting: ");
for (int i = 0; i < n; i++) {
printf("%c ", arr[i]);
}
printf("\n");
return 0;
}
運行此程序,將輸出:
Before sorting: d c a b e
After sorting: a b c d e
在比較函數compare()
中,通過轉換void*
指針為char*
指針,然后比較字符的大小來確定排序規則。然后調用qsort()
函數對字符數組進行排序。