排序算法 | 直接选择排序,算法的图解、实现、复杂度和稳定性分析
生活随笔
收集整理的這篇文章主要介紹了
排序算法 | 直接选择排序,算法的图解、实现、复杂度和稳定性分析
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
排序算法 | 直接選擇排序,算法的圖解、實(shí)現(xiàn)、復(fù)雜度和穩(wěn)定性分析
目錄
- 1、直接選擇排序的原理
- 2、圖解直接選擇排序
- 3、算法代碼實(shí)現(xiàn)
- 4、算法復(fù)雜度分析、穩(wěn)定性分析
直接選擇排序
1、直接選擇排序的原理
基本思想是:選擇 + 交換
下面 以升序?yàn)槔?#xff1b;
1、從待排序列中,尋找最小的元素,和 待排序列中的第一個(gè)元素交換位置,如果本身就是第一個(gè)元素最小,不用處理
2、從剩下的待排序序列中,重復(fù)進(jìn)行上面的步驟,找到最小的,和待排序的第一個(gè)交換位置;
算法設(shè)計(jì):使用兩層循環(huán);
第一層循環(huán),從前到后遍歷每一個(gè)元素
第二層循環(huán),在待排序的序列中便利,尋找 + 交換位置
2、圖解直接選擇排序
int arr[] = {3,24,5,15,26,27,2,4,19,15,48};3、算法代碼實(shí)現(xiàn)
① 使用位運(yùn)算,不需要輔助空間的算法
void SelectSort(int *arr,int len) // 直接選擇排序 {for(int i = 0;i < len-1;i++){for(int j = i+1;j < len;j++){if(arr[i] > arr[j]){arr[i] = arr[i] ^ arr[j]; // 位運(yùn)算,不借助輔助空間 arr[j] = arr[i] ^ arr[j]; arr[i] = arr[i] ^ arr[j];// int tmp = arr[i]; // 有輔助空間 // arr[i] = arr[j]; // arr[j] = tmp;}}} }② 運(yùn)行結(jié)果
4、算法復(fù)雜度分析、穩(wěn)定性分析
① 空間復(fù)雜度:如果交換的時(shí)候使用了輔助空間,就是O(1);
② 時(shí)間復(fù)雜度:O(N); 因?yàn)槭褂昧藘蓪颖闅v~
③ 穩(wěn)定性:不穩(wěn)定;前面說(shuō)過(guò),該算法的基本思想是:選擇 + 交換,所以在交換的時(shí)候,可能就破壞了序列本身的前后關(guān)系;
總結(jié)
以上是生活随笔為你收集整理的排序算法 | 直接选择排序,算法的图解、实现、复杂度和稳定性分析的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: pycharm如何改为中文显示?
- 下一篇: 双指针算法(三):力扣【167.两数之和