标签:字符串数组 排序
//方法一: #include <stdio.h> #include <string.h> void sort(char *arr[], int n) { char *tmp; int i, j, k; for (i = 0; i < n - 1; i++) //选择排序 { k = i; for (j = i + 1; j < n; j++) { if (strcmp(arr[k], arr[j])>0) { k = j; } } tmp = arr[i]; arr[i] = arr[k]; arr[k] = tmp; } } void print(char *arr[], int n) { int i = 0; for (i = 0; i < n; i++) { printf("%s\n", arr[i]); } } int main() { int n = 5; char *arr[] = { "abcde", "efghi", "hijkl", "bcdef", "defgh" }; sort(arr, n); print(arr, n); return 0; } //方法二: #include <stdio.h> #include <string.h> int main() { char arr[5][30] = { "aaaa", "cccc", "bbbb", "eeee", "dddd" }; int i = 0, j = 0; char tmp[30] = { 0 }; for (i = 0; i < 4; i++) //冒泡排序 { for (j = 0; j < 4 - i; j++) { if (strcmp(arr[j], arr[j + 1]) > 0) { strcpy(tmp, arr[j]); strcpy(arr[j], arr[j + 1]); strcpy(arr[j + 1], tmp); } } } for (i = 0; i < 5; i++) { printf("%s\n", arr[i]); } return 0; }
标签:字符串数组 排序
原文地址:http://10706198.blog.51cto.com/10696198/1710583