數據結構算法-排序(一)-冒泡排序

什么是冒泡排序

冒泡排序:在原數組中通過相鄰兩項元素的比較,交換而完成的排序算法。

算法核心

數組中相鄰兩項比較、交換。

算法復雜度

  1. 時間復雜度
    實現一次排序找到最大值需要遍歷 n-1次(n為數組長度)
    需要這樣的排序 n-1次。 需要 (n-1) * (n-1) —> O(n^2)
    時間復雜度: O(n^2)

算法實現原理

我們以一次排序為例,了解冒泡排序是如何完成排序過程的。
相鄰兩項比較交換:

  1. 23 和 7 比較, 23和7 交換位置(23>7大泡泡上升)
  2. 23 和 33 比較, 位置不變。
  3. 33 和15 比較, 33 和15交換位置。
  4. 33 和 34 比較, 位置不變。
  5. 34 和 12 比較, 34和12交換位置。
  6. 第一輪排序結束: 34 作為最大的泡泡上升的數組的lenght-1位置。
    在這里插入圖片描述

參考實現

 for(int i =0; i < a.length; i++){for(int j =0; j < a.length - i-1; j++){if(a[j] > [j+1] ){int tmp = a[j];a[j] = a[j+1];a[j+1] = tmp;}}}

擴展問題

對于已經有序的數組,例如a[] = {1,2,3,4,5,6,7}, 那么冒泡排序還需要進行大量的比較,這樣效率并不高。
[解決方案] 我們可以做一個標記flag = true, 如果進入比較條件則改變flag的值,如果一輪循環之后,發現flag沒有變化,那么說明數組是有序的,則不需要繼續遍歷了。

 for(int i =0; i < a.length; i++){boolean flag = true;for(int j =0; j < a.length - i-1; j++){if(a[j] > [j+1] ){flag = false;int tmp = a[j];a[j] = a[j+1];a[j+1] = tmp;}}if(flag) break;}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/41157.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/41157.shtml
英文地址,請注明出處:http://en.pswp.cn/web/41157.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java事務(Transaction)

Java事務&#xff08;Transaction&#xff09;是數據庫管理系統執行過程中的一個邏輯單位&#xff0c;由一個有限的數據庫操作序列組成&#xff0c;這些操作要么全部執行&#xff0c;要么全部不執行&#xff0c;是一個不可分割的工作單位。事務的引入主要是為了解決并發操作數據…

Unity中遇到“Input Button unload_long_back_btn is not setup”問題

當你在Unity中遇到“Input Button unload_long_back_btn is not setup”這個問題時&#xff0c;需要按照以下步驟進行處理&#xff1a; 1. 檢查按鈕名稱 確保你在代碼中使用的按鈕名稱&#xff08;unload_long_back_btn&#xff09;與Unity輸入管理器中的配置完全匹配。 2. …

[AIGC] ClickHouse分布式表與本地表的區別及如何查詢所有本地表記錄

在大規模數據處理和分析場景中&#xff0c;ClickHouse是一種高性能的列式數據庫管理系統。ClickHouse支持分布式表和本地表兩種表類型&#xff0c;本文將介紹這兩種表類型的區別&#xff0c;并探討如何建表以查詢所有本地表的記錄。 文章目錄 一、ClickHouse分布式表與本地表的…

【Linux進階】文件系統7——文件系統簡單操作

1.磁盤與目錄的容量 現在我們知道磁盤的整體數據是在超級區塊中&#xff0c;但是每個文件的容量則在inode 當中記載。 那在命令行模式下面該如何顯示這幾個數據&#xff1f;下面就讓我們來談一談這兩個命令&#xff1a; df&#xff1a;列出文件系統的整體磁盤使用量&#xf…

Poker Game, Run Fast

Poker Game, Run Fast 撲克&#xff1a;跑得快 分門別類&#xff1a; 單張從小到大默認 A < 2 < 3 < 4 < 5 < 6 < 7 < 8 < 9 < 10 < J < Q < K 跑得快&#xff1a;單張從小到大 3 < 4 < 5 < 6 < 7 < 8 < 9 < 10 &…

javaweb個人主頁設計(html+css+js)

目錄 1 前言和要求 1.1 前言 1.2 設計要求 2 預覽 2.1 主頁頁面 2.2 個人簡介 2.3 個人愛好 2.4 個人成績有代碼&#xff0c;但是圖片已省略&#xff0c;可以根據自己情況添加 2.5 收藏夾 3 代碼實現 3.1 主頁 3.2 個人簡介 3.3 個人愛好 3.4 個人成績&#xff…

大數據處理利器:Apache Spark編程基礎與實戰

"大數據處理利器&#xff1a;Apache Spark編程基礎與實戰" 是一個涵蓋了Apache Spark這一強大大數據處理框架的深入學習和實踐指南。Apache Spark是一個快速、通用、可擴展的大數據處理引擎&#xff0c;它提供了高級別的API用于大規模數據處理和分析。下面&#xff0…

求職成功率的算法,與葫蘆娃救爺爺的算法,有哪些相同與不同

1 本節概述 通過在B站百刷葫蘆娃這部兒時劇&#xff0c;我覺得可以從中梳理出一些算法&#xff0c;甚至可以用于求職這個場景。所以&#xff0c;大家可以隨便問我葫蘆娃的一些劇情和感悟&#xff0c;我都可以做一些回答。 2 葫蘆娃救爺爺有哪些算法可言&#xff1f; 我們知道…

身體(body)的覺醒

佛&#xff0c;是一個梵文的漢語音譯詞&#xff0c;指覺醒者。 何謂覺醒&#xff1f;什么的覺醒&#xff1f;其實很簡單&#xff0c;就是身體的覺醒。 佛的另一個名字&#xff0c;叫菩提&#xff0c;佛就是菩提&#xff0c;菩提老祖&#xff0c;就是佛祖。 body&#xff0c;即…

微服務: 初識 Spring Cloud

什么是微服務? 微服務就像把一個大公司拆成很多小部門&#xff0c;每個部門各自負責一塊業務。這樣一來&#xff0c;每個部門都可以獨立工作&#xff0c;即使一個部門出了問題&#xff0c;也不會影響整個公司運作。 什么是Spring Cloud? Spring Cloud 是一套工具包&#x…

Oracle RAC 19c 打補丁至最新版本-19.23.0.0.0

實驗環境-我是從19.0.0.0直接打到19.23.0.0.0&#xff0c;適合剛部署好的集群打補丁直接到最新版本。 查看當前環境 查詢集群中運行的 Oracle Clusterware 軟件的 activex 版 查詢本地節點上二進制文件中存儲的 Oracle Clusterware 軟件的版本 查詢本地服務器上 OHAS 和 Oracle…

U.S.News發布全美最佳本科AI專業排名

10 加州大學圣迭戈分校 University of California, San Diego UCSD的人工智能項目從事廣泛的理論和實驗研究&#xff0c;學校的優勢領域包括機器學習、不確定性下的推理和認知建模。除了理論學習&#xff0c;UCSD教授非常注重把計算機知識運用到自然語言處理、數據挖掘、計算…

20240707 每日AI必讀資訊

&#x1f9e0;中國生成式AI專利數量超過美國 6 倍 - 中國在2014年至2023年期間申請的生成式AI專利數量達到38210個&#xff0c;超過了美國的6倍。 - 騰訊、平安保險集團和百度是GenAI專利數量最多的中國公司。 - 中國的頂級學術機構和技術生態為生成式AI的發展提供了強大支持…

CC2530寄存器編程學習筆記_點燈

下面是我的CC2530的學習筆記之點燈部分。 第一步&#xff1a;分析原理圖 找到需要對應操作的硬件 圖 1 通過這個圖1我們可以找到LED1和LED2連接的引腳&#xff0c;分別是P1_0和P1_1。 第二步 分析原理圖 圖 2 通過圖2 確認P1_0和P1_1引腳連接到LED&#xff0c;并且這些引…

一體化運維:某省電力公司實現集中統一監控

在當今信息化高速發展的時代&#xff0c;電力公司作為國家基礎設施的重要組成部分&#xff0c;其IT系統的穩定性和高效性直接關系到電力供應的安全與穩定。為了提升運維效率&#xff0c;確保電力系統的持續穩定運行&#xff0c;某省電力公司采購十多套“監控易”運維軟件&#…

高算力智能監控方案:基于瑞芯微RK3576核心板開發NVR網絡視頻錄像機

近年來&#xff0c;隨著人工智能和物聯網技術的不斷發展&#xff0c;網絡視頻錄像機&#xff08;NVR&#xff09;在智能監控領域中的應用越來越廣泛。本文將圍繞RK3576核心板展開討論&#xff0c;探討其在NVR開發中的潛力和優勢。 一、RK3576核心板 RK3576是瑞芯微的新一代中…

14-35 劍和詩人9 - 普及 Agentic RAG

好吧&#xff0c;讓我們直接進入正題——了解 Agentic RAG&#xff08;檢索增強生成&#xff09;方法以及它如何徹底改變我們處理信息的方式。系好安全帶&#xff0c;因為這將變得瘋狂&#xff01; Agentic RAG 的核心在于為 RAG 框架注入智能和自主性。這就像對常規 RAG 系統…

《Windows API 每日一練》8.4 edit控件

編輯類是最簡單的預定義窗口類&#xff0c;而另一方面卻又是最復雜的。當你用“edit”作為類名創建子窗口時&#xff0c;可以基于CreateWindow調用的x坐標、y坐標、寬度和高度參數定義一個矩形。這個矩形包含可編輯的文本。一旦子窗口控件獲得輸入焦點&#xff0c;你就可以輸入…

【文獻解析】Voxelmap——一種自適應體素地圖

Efficient and Probabilistic Adaptive Voxel Mapping for Accurate Online LiDAR Odometry 論文地址&#xff1a;https://ieeexplore.ieee.org/stamp/stamp.jsp?tp&arnumber9813516 代碼&#xff1a;GitHub - hku-mars/VoxelMap: [RA-L 2022] An efficient and probabili…

制冷軟件SOLKANE單級制冷循環計算

SOLKANE軟件下載 單級制冷循環參數介紹 輸入數據&#xff1a; 1.蒸發器&#xff1a; 溫度&#xff1a;蒸發溫度t6&#xff08;露點溫度&#xff09;。 過熱&#xff1a;制冷劑t6-t6在蒸發器中過熱。 壓力損失&#xff1a;蒸發器入口和出口之間的壓力下降。 制冷量&#x…