搜尋
首頁Javajava教程java實作插入排序的實例詳解

java實作插入排序的實例詳解

May 13, 2017 am 11:02 AM
java插入排序資料結構演算法

這篇文章主要介紹了java資料結構與演算法之插入排序,結合實例形式分析了java插入排序的概念、分類、原理、實現方法與相關注意事項,需要的朋友可以參考下

本文實例敘述了java資料結構與演算法之插入排序。分享給大家供大家參考,具體如下:

複習之餘,就將資料結構中關於排序的這塊知識點整理了一下,寫下來是想與更多的人分享,最關鍵的是做一備份,為方便以後查閱。

排序

1、概念:

有n個記錄的序列{R1, R2,.......,Rn}(此處注意:1,2,n 是下表序列,以下是相同的作用),其對應關鍵字的序列為{K1,K2,.... .....,Kn}。透過排序,要求找出目前下標序列1,2,......,n的一種排列p1,p2,........pn,使得對應關鍵字滿足如下的非遞減(非遞增)關係,即:Kp1

2、分類

根據排序時資料所佔用記憶體的不同,可將排序分為兩類。

內部排序:整個排序過程完全在記憶體中進行,如下:

插入類別排序(直接插入排序、折半插入排序、希爾排序);

交換類別排序(冒泡排序、快速排序);

選擇類別排序(簡單選擇排序、樹型選擇排序、堆排序);

歸併排序;

分配類別排序(多關鍵字排序、鍊式基數排序、基數排序的順序表實現));

#外部排序:由於待排序記錄資料量太大,記憶體無法容納全部數據,排序需要藉助外部儲存設備才能完成(磁碟排序,磁帶排序)。

3、穩定性

假設在待排序的序列中存在多個具有相同關鍵字的記錄。設Ki=Kj(1

插入排序:

想法:每次將一個待排序的記錄,按其關鍵字大小插入到前面已經排好序的子檔案中的適當位置,直到全部記錄插入完成為止。

直接插入排序:

演算法想法:假設待排序的記錄存放在陣列R[1.. n]中。初始時,R[1]自成1個有序區,無序區為R[2..n]。從i=2起直至i=n為止,依序將R[i]插入目前的有序區R[1..i-1]中,產生含n個記錄的有序區。

用java實作的程式碼如下:


package exp_sort;
public class DirectInsertSort {
  public static void DircstSort(int array[]) {
    int j;
    // 循环从第二个数开始,第一个数用做存放待插入的记录
    for (int i = 1; i < array.length; i++) {
      int temp = array[i];
      // 寻找插入位置
      for (j = i; j > 0 && temp < array[j - 1]; j--) {
        array[j] = array[j - 1];
      }
      // 将待插入记录插入到已经排序的序列中
      array[j] = temp;
    }
    for (int i = 0; i < array.length; i++) {
      System.out.print(array[i] + " ");
    }
    System.out.println("\n");
  }
  public static void main(String[] args) {
    // TODO Auto-generated method stub
    int array[] = { 38, 62, 35, 77, 55, 14, 35, 98 };
    DircstSort(array);
  }
}

演算法分析:最好的情況是待排序記錄本身已經依照關鍵字有序排列,最壞的情況是待排序記錄是按照關鍵字逆序排列的;時間複雜度是O(N^2),空間複雜度是O(1); 此演算法是穩定的排序演算法:比較適用於待排序記錄數目較少且基本上有序的情況

折半插入排序:

#演算法想法:對於有序表進行折半查找,其效能優於順序查找。

演算法實作程式碼如下:


package exp_sort;
public class BinaryInsertSort {
  public static void sort(int array[]) {
    int temp, low, mid, high;
    for (int i = 1; i < array.length; i++) {
      temp = array[i];
      low = 0;
      high = i -1;
      //确定插入位置
      while (low <= high) {
        mid = (low + high) / 2;
        if (temp < array[mid]) {
          high = mid - 1;
        } else {
          low = mid + 1;
        }
      }
      //记录依次向后移动
      for (int j = i; j >= low + 1; j--) {
        array[j] = array[j-1];
      }
      //插入记录
      array[low] = temp;
    }
    for (int i = 0; i < array.length; i++) {
      System.out.print(array[i] + " ");
    }
    System.out.println("\n");
  }
  public static void main(String[] args) {
    // TODO Auto-generated method stub
    int array[] = {38, 62, 35, 77, 55, 14, 35, 98};
    sort(array);
  }
}

演算法分析:是一種穩定的排序演算法,比直接插入演算法明顯減少了關鍵字之間比較的次數,因此速度比直接插入排序演算法快,但記錄移動的次數沒有變,所以折半插入排序演算法的時間複雜度仍然為O (n^2),與直接插入排序演算法相同。 附加空間O(1)。

【相關推薦】

#1. 特別推薦「php程式設計師工具箱”V0.1版本下載

#

2. Java免費影片教學

#3. YMP線上手冊

##########

以上是java實作插入排序的實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
如何將Maven或Gradle用於高級Java項目管理,構建自動化和依賴性解決方案?如何將Maven或Gradle用於高級Java項目管理,構建自動化和依賴性解決方案?Mar 17, 2025 pm 05:46 PM

本文討論了使用Maven和Gradle進行Java項目管理,構建自動化和依賴性解決方案,以比較其方法和優化策略。

如何使用適當的版本控制和依賴項管理創建和使用自定義Java庫(JAR文件)?如何使用適當的版本控制和依賴項管理創建和使用自定義Java庫(JAR文件)?Mar 17, 2025 pm 05:45 PM

本文使用Maven和Gradle之類的工具討論了具有適當的版本控制和依賴關係管理的自定義Java庫(JAR文件)的創建和使用。

如何使用咖啡因或Guava Cache等庫在Java應用程序中實現多層緩存?如何使用咖啡因或Guava Cache等庫在Java應用程序中實現多層緩存?Mar 17, 2025 pm 05:44 PM

本文討論了使用咖啡因和Guava緩存在Java中實施多層緩存以提高應用程序性能。它涵蓋設置,集成和績效優勢,以及配置和驅逐政策管理最佳PRA

如何將JPA(Java持久性API)用於具有高級功能(例如緩存和懶惰加載)的對象相關映射?如何將JPA(Java持久性API)用於具有高級功能(例如緩存和懶惰加載)的對象相關映射?Mar 17, 2025 pm 05:43 PM

本文討論了使用JPA進行對象相關映射,並具有高級功能,例如緩存和懶惰加載。它涵蓋了設置,實體映射和優化性能的最佳實踐,同時突出潛在的陷阱。[159個字符]

Java的類負載機制如何起作用,包括不同的類載荷及其委託模型?Java的類負載機制如何起作用,包括不同的類載荷及其委託模型?Mar 17, 2025 pm 05:35 PM

Java的類上載涉及使用帶有引導,擴展程序和應用程序類負載器的分層系統加載,鏈接和初始化類。父代授權模型確保首先加載核心類別,從而影響自定義類LOA

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具