日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

排序算法 | 直接选择排序,算法的图解、实现、复杂度和稳定性分析

發(fā)布時(shí)間:2025/3/20 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 排序算法 | 直接选择排序,算法的图解、实现、复杂度和稳定性分析 小編覺得挺不錯(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)定;前面說過,該算法的基本思想是:選擇 + 交換,所以在交換的時(shí)候,可能就破壞了序列本身的前后關(guān)系;

總結(jié)

以上是生活随笔為你收集整理的排序算法 | 直接选择排序,算法的图解、实现、复杂度和稳定性分析的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。