中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java冒泡排序法和選擇排序法怎么運用

發布時間:2022-03-22 15:43:32 來源:億速云 閱讀:104 作者:iii 欄目:互聯網科技

這篇文章主要講解了“Java冒泡排序法和選擇排序法怎么運用”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Java冒泡排序法和選擇排序法怎么運用”吧!

冒泡排序法

冒泡排序法冒泡算法,在傳統的C語言教科書上講的很多,它是一種比較穩定的排序算法。大家在使用這個排序算法的時候,可以從它的名字來聯想一下它的實現形式。一說到冒泡,大家首先想到的是一條小魚在水里游著,并且“布魯布魯”的吐出一串串小氣泡,冒到水面上。其實冒泡排序法也和小于吐泡泡一樣,每次只吐出一個,并且連續不斷地一個接一個吐。冒泡排序算法的中心思想,即是相鄰的兩個數進行比較后根據大小需求交換位置。先從最簡單的兩個元素的數組看起,由此進行舉一反三。假設一個數組內部只有兩個元素“int array = {8, 0};”。對其進行排序時,我們僅需要做一次判斷即可以知道哪個元素大,哪個元素小,假設我們從小到大進行排列,那么排列出的結果就應該是“array = {0, 8};”。再看當有三個元素的數組。假設一個數組內部只有兩個元素“int array = {8, 0, 1};”。那我們還是進行兩兩比較,第一次比較,可以得出數組應該為“array = {0, 1, 8};”,也是只需要一次比較就可以完成數組的排序。但如果數組改變一下元素的位置,即“int array = {8, 1, 0};”,那么我們再來看一下,第一次兩兩元素比較變成了“array = {1, 0, 8};”,因此碰到這種極端情況時,冒泡法一次比較完成不了排序,那么應該進行第二次比較,最終第二次比較我們可以得出結果“array = {0, 1, 8};”再來看看四個元素時候數組的排序,這次我們舉一個極端情況,即將一個從大到小排列的數組變成由小到大的順序排列。數組為“int array = {9, 8, 1, 0};”。那么此時第一次相鄰兩個元素比較可以得出“array = {8, 1, 0, 9};”,第二次相鄰元素兩兩比較可以得出“array = {1, 0, 8, 9};”,第三次兩兩比較可以得出“array = {0, 1, 8, 9};”。基于上述的分析,我們可以知道,一個數組如果有n個元素需要進行排序時,其排序的極端情況應該是n-1次。具體的排序流程,如下。                           

 Java冒泡排序法和選擇排序法怎么運用

冒泡排序法的流程
因此根據上述分析,我們可以寫出代碼如下。

Java冒泡排序法和選擇排序法怎么運用

接下來,我們將程序改裝一下,讓它在每一步相鄰兩個元素比較的過程打印出來,如圖5-4-3所示。我們可以看到,越大的元素會經由交換慢慢“浮”到數列的頂端(升序或降序排列),就如同水里的小金魚吐出的泡泡一串串慢慢浮出水面,故名“冒泡排序”。

Java冒泡排序法和選擇排序法怎么運用

冒泡法排序單步打印 

選擇排序法

選擇排序選擇排序,俗稱“硬著頭皮排序”,當然這個“硬著頭皮排序”是我給它取的名字,因為它是最最直觀的排序方法,完美詮釋了“暴力美學”這四個字。要理解選擇排序,先想象一下小學上體育課時,老師是怎么排列隊伍的。先從小朋友里面隨便拉一個老師認為最矮的同學出來,讓他做排頭,然后依次拿其他的同學和他比較,如果比他高,就放到其后面去,比他矮就放到前面,接著再來目測第二個,以此類推。當然上面這段話是描述的體育老師內心思路。而我們對數組排序的時候,同樣可以使用這種方式。我們可以先指定一個排頭兵,假設我們要進行從小到大排列時,那我們先假設第一個元素為數組中最小的元素,接著分別去和剩余的其它元素比較,如果發現比它小的,那么將其自己和那個元素互換,用這種方式,只需要遍歷完整個數組,就可以把最小的元素放到首個元素的位置了。如下所示。

Java冒泡排序法和選擇排序法怎么運用

選擇排序做一次遍歷比較


上圖中,我們通過第一次的遍歷比較,將最小的元素排列到了數組的最左端,而接下來要做的,只需要一次將剩余的9個元素進行比較,找出最小值,再放到0右邊,以此類推,最后我們可以寫出如下圖所示的選擇排序程序。

Java冒泡排序法和選擇排序法怎么運用

感謝各位的閱讀,以上就是“Java冒泡排序法和選擇排序法怎么運用”的內容了,經過本文的學習后,相信大家對Java冒泡排序法和選擇排序法怎么運用這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

广东省| 开江县| 常宁市| 陇南市| 金沙县| 新干县| 康定县| 调兵山市| 舞阳县| 龙陵县| 龙州县| 西林县| 资源县| 丁青县| 桂阳县| 湟中县| 浦县| 句容市| 灵武市| 青铜峡市| 盐津县| 民权县| 正定县| 寻乌县| 承德市| 洱源县| 武清区| 德安县| 贵定县| 大同县| 福鼎市| 贡嘎县| 师宗县| 昌平区| 泗洪县| 天台县| 德州市| 恩施市| 阳西县| 临清市| 东明县|