排序演算法之冒泡排序

来源:http://www.cnblogs.com/zhaoguhong/archive/2017/09/03/7471511.html
-Advertisement-
Play Games

冒泡排序是一種非常常見的排序演算法。如同水中的一排泡泡,先冒出最大的一個泡泡。再冒出剩餘泡泡中的最大泡泡,依次類推,它的排序規則如下: 1. 從第一個元素開始,比較相鄰的兩個元素,如果後面的小於前面的,交換兩個的位置,一直比較到最後一個 2. 迴圈1中的操作,但已經確定的最大的元素不再參與比較 3. ...


冒泡排序是一種非常常見的排序演算法。如同水中的一排泡泡,先冒出最大的一個泡泡。再冒出剩餘泡泡中的最大泡泡,依次類推,它的排序規則如下:

  1. 從第一個元素開始,比較相鄰的兩個元素,如果後面的小於前面的,交換兩個的位置,一直比較到最後一個
  2. 迴圈1中的操作,但已經確定的最大的元素不再參與比較
  3. 直到不確定大小順序的元素剩餘兩個,然後對這兩個進行比較,然後結束迴圈

排序圖示(圖片來源網路)

java實現

用java實現一個簡單的冒泡排序。為了便於理解,在尋找到第一個最大元素完成後,稱之為第一趟,依次類推,可以發現一共需要n-1趟

  public void bubbleSort() {
    int[] array = {6, 2, 5, 3};
    for (int i = 0; i < array.length - 1; i++) {// 需要排序的趟數
      for (int j = 0; j < array.length - i - 1; j++) {// 每一趟需要比較的次數
        if (array[j + 1] < array[j]) {
          int variable = array[j + 1];
          array[j + 1] = array[j];
          array[j] = variable;
        }
      }
      System.out.println("第" + (i + 1) + "趟排序後的結果:" + Arrays.toString(array));
    }
    System.out.println("最終的排序結果:" + Arrays.toString(array));
  }

console

1趟排序後的結果:[2, 5, 3, 6]
第2趟排序後的結果:[2, 3, 5, 6]
第3趟排序後的結果:[2, 3, 5, 6]
最終的排序結果:[2, 3, 5, 6]

排序過程分析

第一趟排序

排序前:[6, 2, 5, 3]
排序後:[2, 5, 3, 6]
6與2比較,然後互換位置,然後與5比較,互換位置,最後與3比較,互換位置,此時6在最後的位置,確定最大值6,一共比較3次

第二趟排序

排序前:[2, 5, 3, 6]
排序後:[2, 3, 5, 6]
2與3比較,位置不變,然後5與3比較,然後互換位置,因為6的位置已經確定,所以5與6不再比較,一共比較2次

第三趟排序

排序前:[2, 3, 5, 6]
排序後:[2, 3, 5, 6]
2與3比較,位置不變,5,6的位置已經確定,所以不再比較,一共比較1次

由上面的分析可以看出,一共進行了1+2+...+n-1次比較。也就是n(n-1)/2次,即(N^2 - n)/2次,去除對結果影響不大的N^2 - n中的-n,以及繫數0.5,得出時間複雜度為 O(N^2) (註:此處的時間複雜度自己尚未完全理解,希望明白的朋友可以給予解答)

優化

上述的排序還存在優化的空間,如果本來就是一列從小到大的數,按上述操作,很容易造成資源浪費。最理想的情況下,對於一列從小到大的數,進行n次比較,即可得出結果。如果某一趟排序中,沒有出現互換操作,即表示已經得到了正確的結果,此時可以結束排序,示例如下:

  public void bubbleSort() {
    int[] array = {6, 2, 5, 3};
    for (int i = 0; i < array.length - 1; i++) {// 需要排序的趟數
      boolean flag = false;// 預設不存在位置交換
      for (int j = 0; j < array.length - i - 1; j++) {// 每一趟需要比較的次數
        if (array[j + 1] < array[j]) {
          flag = true;// 存在位置交換,修改flag為true
          int variable = array[j + 1];
          array[j + 1] = array[j];
          array[j] = variable;
        }
      }
      if (!flag) {
        break;// 不存在位置交換 跳出迴圈
      }
    }
    System.out.println("最終的排序結果:" + Arrays.toString(array));
  }

作者:zhaoguhong(趙孤鴻)

出處:http://www.cnblogs.com/zhaoguhong/

本文版權歸作者和博客園共有,轉載請註明出處


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 套用mui官方文檔的一句話:“開發者只需關心業務邏輯,實現載入更多數據即可”。真的是不錯的框架。 想更多的瞭解這個框架:http://dev.dcloud.net.cn/mui/ 那麼如何實現下拉刷新,上拉載入的功能呢? 首先需要一個容器: 然後進行初始化操作,通過mui.init方法中pullRe ...
  • 一、WCF技術我該如何學習? 阿笨的回答是:作為初學者的我們,那麼請跟著阿笨一起玩WCF吧,阿笨將帶領大家如何以正確的姿勢去掌握WCF技術。由於WCF技術知識點太多了,就純基礎概念性知識都可以單獨出一本書來講解,本次分享課程《C#面向服務編程技術WCF從入門到實戰演練》開課之前,阿笨還是希望從沒瞭解 ...
  • 開篇先來說一下我和來畫的故事,以及寫這篇文章的初衷。 今年年初時,我還在北京,在 Face++,做著人臉識別技術的 Windows 和 Android 端,做著人工智慧終將實現世間所有美好的夢。這時的我已經離開 UWP,甚至 C# 很久了,寫著 C++ 和 Java,當時真的沒想過會再次回到 UWP ...
  • 自己畫一個轉圈圈的控制項 ...
  • 首先說一下foreach有的也叫增強for迴圈,foreach其實是for迴圈的一個特殊簡化版。 再說一下foreach的書寫格式: for(元素類型 元素名稱 : 遍曆數組(集合)(或者能進行迭代的)){ 語句 } foreach雖然是for迴圈的簡化版本,但是並不是說foreach就比for更好 ...
  • 特別聲明本隨筆copy於egon(林海峰)。 一 IO模型介紹 為了更好地瞭解IO模型,我們需要事先回顧下:同步、非同步、阻塞、非阻塞 同步(synchronous) IO和非同步(asynchronous) IO,阻塞(blocking) IO和非阻塞(non-blocking)IO分別是什麼,到底有 ...
  • 建立資料庫訪問類的封裝 <?php class DBDA { public $host = "localhost"; //伺服器地址 public $uid = "root"; //資料庫的用戶名 public $pwd = ""; //資料庫的密碼 public $dbname = "";//數據 ...
  • Spring與SpringMVC整合! 問:實際上SpringMVC就運行在Spring環境之下,還有必要整合麽?SpringMVC和Spring都有IOC容器,是不是都需要保留呢? 答案是:通常情況下,類似於數據源,事務,整合其他框架都是放在spring的配置文件中(而不是放在SpringMVC的 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...