今天小編給大家分享一下怎么運(yùn)用Java語言實(shí)現(xiàn)冒泡排序和選擇排序算法的相關(guān)知識點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)提供從項(xiàng)目策劃、軟件開發(fā),軟件安全維護(hù)、網(wǎng)站優(yōu)化(SEO)、網(wǎng)站分析、效果評估等整套的建站服務(wù),主營業(yè)務(wù)為網(wǎng)站制作、做網(wǎng)站,成都APP應(yīng)用開發(fā)以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。創(chuàng)新互聯(lián)公司深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!
冒泡排序法 |
冒泡排序法冒泡算法,在傳統(tǒng)的C語言教科書上講的很多,它是一種比較穩(wěn)定的排序算法。大家在使用這個排序算法的時(shí)候,可以從它的名字來聯(lián)想一下它的實(shí)現(xiàn)形式。一說到冒泡,大家首先想到的是一條小魚在水里游著,并且“布魯布魯”的吐出一串串小氣泡,冒到水面上。其實(shí)冒泡排序法也和小于吐泡泡一樣,每次只吐出一個,并且連續(xù)不斷地一個接一個吐。冒泡排序算法的中心思想,即是相鄰的兩個數(shù)進(jìn)行比較后根據(jù)大小需求交換位置。先從最簡單的兩個元素的數(shù)組看起,由此進(jìn)行舉一反三。假設(shè)一個數(shù)組內(nèi)部只有兩個元素“int array = {8, 0};”。對其進(jìn)行排序時(shí),我們僅需要做一次判斷即可以知道哪個元素大,哪個元素小,假設(shè)我們從小到大進(jìn)行排列,那么排列出的結(jié)果就應(yīng)該是“array = {0, 8};”。再看當(dāng)有三個元素的數(shù)組。假設(shè)一個數(shù)組內(nèi)部只有兩個元素“int array = {8, 0, 1};”。那我們還是進(jìn)行兩兩比較,第一次比較,可以得出數(shù)組應(yīng)該為“array = {0, 1, 8};”,也是只需要一次比較就可以完成數(shù)組的排序。但如果數(shù)組改變一下元素的位置,即“int array = {8, 1, 0};”,那么我們再來看一下,第一次兩兩元素比較變成了“array = {1, 0, 8};”,因此碰到這種極端情況時(shí),冒泡法一次比較完成不了排序,那么應(yīng)該進(jìn)行第二次比較,最終第二次比較我們可以得出結(jié)果“array = {0, 1, 8};”再來看看四個元素時(shí)候數(shù)組的排序,這次我們舉一個極端情況,即將一個從大到小排列的數(shù)組變成由小到大的順序排列。數(shù)組為“int array = {9, 8, 1, 0};”。那么此時(shí)第一次相鄰兩個元素比較可以得出“array = {8, 1, 0, 9};”,第二次相鄰元素兩兩比較可以得出“array = {1, 0, 8, 9};”,第三次兩兩比較可以得出“array = {0, 1, 8, 9};”?;谏鲜龅姆治?,我們可以知道,一個數(shù)組如果有n個元素需要進(jìn)行排序時(shí),其排序的極端情況應(yīng)該是n-1次。具體的排序流程,如下。
冒泡排序法的流程
因此根據(jù)上述分析,我們可以寫出代碼如下。
接下來,我們將程序改裝一下,讓它在每一步相鄰兩個元素比較的過程打印出來,如圖5-4-3所示。我們可以看到,越大的元素會經(jīng)由交換慢慢“浮”到數(shù)列的頂端(升序或降序排列),就如同水里的小金魚吐出的泡泡一串串慢慢浮出水面,故名“冒泡排序”。
冒泡法排序單步打印
選擇排序法
選擇排序選擇排序,俗稱“硬著頭皮排序”,當(dāng)然這個“硬著頭皮排序”是我給它取的名字,因?yàn)樗亲钭钪庇^的排序方法,完美詮釋了“暴力美學(xué)”這四個字。要理解選擇排序,先想象一下小學(xué)上體育課時(shí),老師是怎么排列隊(duì)伍的。先從小朋友里面隨便拉一個老師認(rèn)為最矮的同學(xué)出來,讓他做排頭,然后依次拿其他的同學(xué)和他比較,如果比他高,就放到其后面去,比他矮就放到前面,接著再來目測第二個,以此類推。當(dāng)然上面這段話是描述的體育老師內(nèi)心思路。而我們對數(shù)組排序的時(shí)候,同樣可以使用這種方式。我們可以先指定一個排頭兵,假設(shè)我們要進(jìn)行從小到大排列時(shí),那我們先假設(shè)第一個元素為數(shù)組中最小的元素,接著分別去和剩余的其它元素比較,如果發(fā)現(xiàn)比它小的,那么將其自己和那個元素互換,用這種方式,只需要遍歷完整個數(shù)組,就可以把最小的元素放到首個元素的位置了。如下所示。
選擇排序做一次遍歷比較
上圖中,我們通過第一次的遍歷比較,將最小的元素排列到了數(shù)組的最左端,而接下來要做的,只需要一次將剩余的9個元素進(jìn)行比較,找出最小值,再放到0右邊,以此類推,最后我們可以寫出如下圖所示的選擇排序程序。
以上就是“怎么運(yùn)用Java語言實(shí)現(xiàn)冒泡排序和選擇排序算法”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。