Java集合排序詳解

一、選擇排序

選擇排序(Selection sort) 是一種簡單直觀的排序算法,其基本思想是:首先在序列中找到最小值,然後將其放到序列的起始位置;接着再從剩餘未排序的元素中繼續尋找最小值,然後放到已排序序列的末尾。以此類推,直到所有的元素都排完為止。下面是該排序算法的代碼實現:

public static void selectionSort(Integer[] arr) {
    int minIndex, temp;
    for (int i = 0; i < arr.length - 1; i++) {
        minIndex = i;
        for (int j = i + 1; j < arr.length; j++) {
            if (arr[j] < arr[minIndex]) {
                minIndex = j;
            }
        }
        temp = arr[i];
        arr[i] = arr[minIndex];
        arr[minIndex] = temp;
    }
}

選擇排序的時間複雜度是O(n^2),是一種較慢的排序算法。

二、冒泡排序

冒泡排序(Bubble sort) 是一種簡單直觀的排序算法,其基本思想是:依次比較相鄰兩個元素的大小關係,如果順序不對,則進行交換。一次排序可以讓最大的元素浮到序列的末尾;接着繼續進行下一輪排序,直到排序完成。下面是該排序算法的代碼實現:

public static void bubbleSort(Integer[] arr) {
    int temp;
    for (int i = 0; i < arr.length - 1; i++) {
        for (int j = 0; j  arr[j + 1]) {
                temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}

冒泡排序的時間複雜度是O(n^2),也是一種較慢的排序算法。

三、插入排序

插入排序(Insertion sort) 是一種簡單直觀的排序算法,其基本思想是:將一個元素插入到已經排好序的序列中,使得插入後仍然有序。插入排序的實現通常採用就地排序的方法,即在原數組上進行操作,不需要額外的存儲空間。下面是該排序算法的代碼實現:

public static void insertionSort(Integer[] arr) {
    int preIndex, current;
    for (int i = 1; i = 0 && arr[preIndex] > current) {
            arr[preIndex + 1] = arr[preIndex];
            preIndex--;
        }
        arr[preIndex + 1] = current;
    }
}

插入排序的時間複雜度是O(n^2),但在序列基本有序的情況下,插入排序的效率非常高。

四、快速排序

快速排序(Quick sort) 是一種高效的排序算法,其基本思想是:選擇一個元素作為基準值,將序列中小於基準值的元素放到基準值的左邊,將大於基準值的元素放到基準值的右邊。然後對左右兩個子序列分別進行快速排序,直到整個序列有序。下面是該排序算法的代碼實現:

public static void quickSort(Integer[] arr, int left, int right) {
    if (left < right) {
        int i = left, j = right, pivot = arr[left];
        while (i < j) {
            while (i = pivot) {
                j--;
            }
            if (i < j) {
                arr[i++] = arr[j];
            }
            while (i < j && arr[i] <= pivot) {
                i++;
            }
            if (i < j) {
                arr[j--] = arr[i];
            }
        }
        arr[i] = pivot;
        quickSort(arr, left, i - 1);
        quickSort(arr, i + 1, right);
    }
}

快速排序的時間複雜度平均情況下是O(nlogn),最壞情況下是O(n^2)。

五、歸併排序

歸併排序(Merge sort) 是一種高效的排序算法,其基本思想是:將序列分成兩個子序列,分別對子序列進行排序,然後將排好序的子序列合併成一個有序的序列。歸併排序使用了分治的思想,以遞歸方式實現。下面是該排序算法的代碼實現:

public static void mergeSort(Integer[] arr, int left, int right) {
    if (left < right) {
        int middle = (left + right) / 2;
        mergeSort(arr, left, middle);
        mergeSort(arr, middle + 1, right);
        merge(arr, left, middle, right);
    }
}

public static void merge(Integer[] arr, int left, int middle, int right) {
    int[] temp = new int[right - left + 1];
    int i = left, j = middle + 1, k = 0;
    while (i <= middle && j <= right) {
        if (arr[i] < arr[j]) {
            temp[k++] = arr[i++];
        } else {
            temp[k++] = arr[j++];
        }
    }
    while (i <= middle) {
        temp[k++] = arr[i++];
    }
    while (j <= right) {
        temp[k++] = arr[j++];
    }
    for (i = 0; i < k; i++) {
        arr[left + i] = temp[i];
    }
}

歸併排序的時間複雜度是O(nlogn),但實現比較複雜,需要額外的存儲空間。

原創文章,作者:BKLCT,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/361586.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
BKLCT的頭像BKLCT
上一篇 2025-02-25 18:17
下一篇 2025-02-25 18:17

相關推薦

  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Bean加載過程

    Java Bean加載過程涉及到類加載器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean加載的過程。 一、類加載器 類加載器是Java虛擬機…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發布。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字符串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字符串中是否存在多個指定字符: 一、字符串遍歷 字符串是Java編程中非常重要的一種數據類型。要判斷字符串中是否存在多個指定字符…

    編程 2025-04-29
  • VSCode為什麼無法運行Java

    解答:VSCode無法運行Java是因為默認情況下,VSCode並沒有集成Java運行環境,需要手動添加Java運行環境或安裝相關插件才能實現Java代碼的編寫、調試和運行。 一、…

    編程 2025-04-29
  • Java任務下發回滾系統的設計與實現

    本文將介紹一個Java任務下發回滾系統的設計與實現。該系統可以用於執行複雜的任務,包括可回滾的任務,及時恢復任務失敗前的狀態。系統使用Java語言進行開發,可以支持多種類型的任務。…

    編程 2025-04-29
  • Java 8 Group By 會影響排序嗎?

    是的,Java 8中的Group By會對排序產生影響。本文將從多個方面探討Group By對排序的影響。 一、Group By的概述 Group By是SQL中的一種常見操作,它…

    編程 2025-04-29

發表回復

登錄後才能評論