1. 程式人生 > >氣泡排序多個字串

氣泡排序多個字串

氣泡排序數組裡的數字,應該都做過,那排序多個字串呢?
冒泡法,它重複地訪問要排序的數列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。時間複雜度O(n)。
冒泡法
這裡是多個字串,在文字常量區,除了可以用指標進行操作之外,還可以進行“字串自己的辦法”

void bubble_sort(char(*arr)[6], int len)//因為arr是個二維陣列,這是以一維陣列進行操作,所以要先將arr解以用
{
    assert(arr);//檢查arr不為空
    assert(len > 0);
    int i, j;
    int flag;//標識
    for (i = 0
; i < len - 1; i++) { flag = 0;//每一輪比較前flag都置為0 for (j = 0; j < len - 1 - i; j++) { if (strcmp(arr[j], arr[j + 1])>0) { flag = 1;//如果需要交換,將flag置為1 char buf[6]; strcpy(buf, arr[j]); strcpy
(arr[j], arr[j+1]); strcpy(arr[j+1], buf); } } if (flag == 0)//走到這如果flag是0,說明這一輪這個數字從第一個一直比到len-1-i都不需要交換, //說明此時這個陣列已經是有序的了,則需要下一輪的冒泡,設定flag可以提高它的效率 break; } } int main() { char arr[][16] = { "bbbbb", "ddddd", "fffff", "ggggg"
, "hhhhh",}; int len = sizeof(arr) / sizeof(arr[0]); bubble_sort(arr, len); return 0; }

如果有不對的地方,可以評論告訴我,望指導!