Java實現數組排序

介紹

排序是程序設計中常用的演算法之一。在現實生活中,很多問題都需要對數據進行排序,比如搜索引擎對搜索結果按相關性排序、股票交易中根據股票價格排序等。在 Java 中,對數組進行排序也是常見的操作,通常使用 Arrays 類中的 sort() 方法實現。本文將從多個方面介紹 Java 中數組排序的相關知識。

排序演算法

排序演算法是指將一組數據按照某個順序重新排列的過程,常見的排序演算法有冒泡排序、選擇排序、插入排序、快速排序等。

冒泡排序

冒泡排序是一種簡單的排序演算法,工作原理是通過相鄰元素之間的比較和交換,每次操作將數組中最大(或最小)的元素 “冒泡” 到最後(或最前)的位置。在實現冒泡排序時,通常使用雙重循環來遍曆數組中的元素:


public static void bubbleSort(int[] arr) {
    int n = arr.length;
    for (int i = 0; i < n - 1; i++) {
        for (int j = 0; j < n - 1 - i; j++) {
            // 如果前一個元素比後一個元素大,則交換兩個元素的位置
            if (arr[j] > arr[j + 1]) {
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}

選擇排序

選擇排序的工作原理是搜索數組中最小值(或最大值),並將其放置在第一個位置;接著,在剩餘的數組中搜索第二小值(或第二大值),並將其放置在第二個位置;以此類推,直到整個數組排序完成。選擇排序的實現也很簡單,可以使用雙重循環進行:


public static void selectionSort(int[] arr) {
    int n = arr.length;
    for (int i = 0; i < n - 1; i++) {
        int minIdx = i;
        for (int j = i + 1; j < n; j++) {
            // 找到最小元素的下標
            if (arr[j] < arr[minIdx]) {
                minIdx = j;
            }
        }
        // 將最小元素與第 i 個元素交換位置
        int temp = arr[i];
        arr[i] = arr[minIdx];
        arr[minIdx] = temp;
    }
}

插入排序

插入排序的工作原理是將未排序的元素插入到已排序好的子序列中,初始狀態下已排序的子序列只包含第一個元素。在遍曆數組過程中,將當前元素與已排序的子序列中的元素比較,找到該元素對應的位置並插入。插入排序同樣可以使用雙重循環進行:


public static void insertionSort(int[] arr) {
    int n = arr.length;
    for (int i = 1; i < n; i++) {
        int key = arr[i];
        int j = i - 1;
        // 將比 key 大的元素向右移動一位,空出 key 的位置
        while (j >= 0 && arr[j] > key) {
            arr[j + 1] = arr[j];
            j--;
        }
        // 將 key 插入到正確的位置
        arr[j + 1] = key;
    }
}

快速排序

快速排序是一種比較高效的排序演算法,其基本思路是通過一趟排序將待排記錄分隔成獨立的兩部分,其中一部分記錄的關鍵字值均比另一部分記錄的關鍵字值小,則可分別對這兩部分記錄繼續進行排序,以達到整個序列有序的目的。在實現快速排序時,通常使用遞歸方式進行:


public static void quickSort(int[] arr, int left, int right) {
    if (left < right) {
        int pivotIdx = partition(arr, left, right);
        quickSort(arr, left, pivotIdx - 1);
        quickSort(arr, pivotIdx + 1, right);
    }
}
private static int partition(int[] arr, int left, int right) {
    int pivot = arr[right];
    int i = left;
    for (int j = left; j < right; j++) {
        if (arr[j] <= pivot) {
            int temp = arr[j];
            arr[j] = arr[i];
            arr[i] = temp;
            i++;
        }
    }
    int temp = arr[right];
    arr[right] = arr[i];
    arr[i] = temp;
    return i;
}

Arrays.sort() 方法

Java 提供了 Arrays 類,該類提供了許多操作數組的方法。其中的 sort() 方法可以對數組進行排序,sort() 方法使用快速排序演算法實現。該方法的基本使用方式如下:


int[] arr = {4, 2, 9, 7};
Arrays.sort(arr);

如果要對數組按從大到小排序,可以使用 sort() 方法的重載版本,並傳入自定義的 Comparator 對象:


int[] arr = {4, 2, 9, 7};
Arrays.sort(arr, (a, b) -> b - a);

總結

本文介紹了 Java 中常見的數組排序演算法,包括冒泡排序、選擇排序、插入排序和快速排序,並提供了每個演算法的實現代碼。此外,也介紹了使用 Arrays 類的 sort() 方法對數組進行排序的方式。掌握了這些知識,讀者可以在實際項目中根據不同情況選擇合適的排序演算法。

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

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
GICNX的頭像GICNX
上一篇 2025-01-09 12:13
下一篇 2025-01-09 12:13

相關推薦

  • 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
  • Python導入數組

    本文將為您詳細闡述Python導入數組的方法、優勢、適用場景等方面,並附上代碼示例。 一、numpy庫的使用 numpy是Python中一個強大的數學庫,其中提供了非常豐富的數學函…

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

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

    編程 2025-04-29
  • Python返回數組:一次性搞定多種數據類型

    Python是一種多用途的高級編程語言,具有高效性和易讀性的特點,因此被廣泛應用於數據科學、機器學習、Web開發、遊戲開發等各個領域。其中,Python返回數組也是一項非常強大的功…

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

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

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

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

    編程 2025-04-29

發表回復

登錄後才能評論