【算法】排序(一)選擇排序

Google Image

在排序算法中,最簡單的莫過于選擇排序了。


本文將介紹以下內容

排序思路
算法實現(JAVA)
測試階段
算法分析

排序思路:

在選擇排序算法中分別有一個外循環和一個內循環,假設需要排序的序列共有n個元素,所以外循環的次數為n次,在n次交換(外循環)中,每次設置序列中的第一個元素為最小值(min),然后進行內循環,每次內循環都將序列中與min比較,若有元素小于min,則進行交換(若沒有,min自己與自己交換)。所以內循環的次數暫時不確定。

簡而言之,就是在未排序的序列中,每次選取序列首位元素,依次與序列中其他元素比較,進而交換元素,達到排序的效果。

算法實現

1.外循環

      public static void selectionSort(int[] a){
          int n = a.length;
          for (int i = 0; i < n; i++) {                      //外循環共n次
              int min = i;
              int temp = a[i];                               //
              a[i] = a[min];                                 // 交換元素
              a[min] = temp;                                 //
          } 
      } 

共有n次交換

2.內循環(比較大小并交換元素索引)

        for (int j = i + 1; j < n; j++) {
                 if(a[j] < a[min]){
                    min = j;                 //如果由元素小于min,則交換元素索引
                }
        }

j = i + 1, i +2 , i + 3 ... n.
共有n - i - 1次比較,比較的次數將會在下文提及。

3.交換元素

        int temp = a[i];
        a[i] = a[min];
        a[min] = temp;

所以,選擇排序的代碼塊

就是如此了:

public static void selectionSort(int[] a){
        int n = a.length;
        for (int i = 0; i < n; i++) {
            int min = i;
            for (int j = i + 1; j < n; j++) {
                if(a[j] < a[min]){
                    min = j;
                }
            }
            int temp = a[i];
            a[i] = a[min];
            a[min] = temp;
        } 
    }

測試階段

我們來寫一個測試數據:

public static void main(String[] args){
        int[] a = new int[10];
        for (int i = 0; i < a.length; i++) {
            a[i] = (int)(Math.random()*100);      //隨機輸入測試數據
            System.out.print(a[i] + " ");
        }
        System.out.println();
        selectionSort(a);
        for (int i = 0; i < a.length; i++) {
            System.out.print(a[i] + " ");
        }
    }

隨機選取幾組排序結果:


test 1
test 2
test 3

算法分析:

1. 特點
  1. 運行時間與輸入數據無關,運行時間與數組大小成線性相關,無論
    初始數據的有序性如何,都不會改變元素交換的次數。

  2. 數據的移動最少,這是其他排序所不能比的,每次外循環使數據移
    動一次,所以選擇排序的數據移動次數為 n 次。

2. 時間復雜度
  • 內循環:n 次交換

  • 外循環:比較的次數隨著i的增長而減少,每次內循環有n -1 - i 次比
    較,總共比較次數:
    (n - 1) + (n - 2) + ... + 2 + 1 = n(n - 1) / 2

  • 基本操作總數: n + n(n - 1) /2 = n(n + 1) / 2 ~ n2/2

  • 所以,時間復雜度為O(n2),平方級別

3. 空間復雜度
  • 在交換素組元素時,需要建立一個臨時變量來幫助交換元素,所以空間復雜度為O(1)
4. 穩定性
  • 由于選擇排序在排序前后會打亂相同鍵值元素的相對順序,所以選擇排序是不穩定的

關于選擇排序的說明就到這里了,下一篇將會是 冒泡排序

給顆紅心,舉手之勞, 謝謝!

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 概述 排序有內部排序和外部排序,內部排序是數據記錄在內存中進行排序,而外部排序是因排序的數據很大,一次不能容納全部...
    蟻前閱讀 5,222評論 0 52
  • 概述:排序有內部排序和外部排序,內部排序是數據記錄在內存中進行排序,而外部排序是因排序的數據很大,一次不能容納全部...
    每天刷兩次牙閱讀 3,746評論 0 15
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 將一個記錄插入到已排序好...
    依依玖玥閱讀 1,286評論 0 2
  • 總結一下常見的排序算法。 排序分內排序和外排序。內排序:指在排序期間數據對象全部存放在內存的排序。外排序:指在排序...
    jiangliang閱讀 1,377評論 0 1
  • 就在昨天,老媽和我微信視頻,說:聽說你買了一輛車。可不是嗎?我終于買了一輛自行車。哈哈哈哈,兩人不約大笑。 我買了...
    木木木俠閱讀 985評論 0 4