氣泡排序多個字串
阿新 • • 發佈:2019-02-15
氣泡排序數組裡的數字,應該都做過,那排序多個字串呢?
冒泡法,它重複地訪問要排序的數列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。時間複雜度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;
}
如果有不對的地方,可以評論告訴我,望指導!