国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Ruby - 冒泡排序算法及Ruby版的簡單實現(xiàn)

冒泡排序算法及Ruby版的簡單實現(xiàn)

2020-05-10 14:44lvpro Ruby

冒泡排序為最基本的排序算法之一,其時間復雜度為O(n^2),這里我們就來簡單看一下冒泡排序算法及Ruby版的簡單實現(xiàn),首先還是先來了解算法原理:

算法原理:

比較相鄰的元素。如果第一個比第二個大,就交換他們兩個。
對每一對相鄰元素作同樣的工作,從開始第一對到結尾的最后一對。在這一點,最后的元素應該會是最大的數(shù)。
針對所有的元素重復以上的步驟,除了最后一個。
持續(xù)每次對越來越少的元素重復上面的步驟,直到?jīng)]有任何一對數(shù)字需要比較。

實現(xiàn)
假設有這樣一個數(shù)組: [4, 1, 3, 2]
冒泡排序為從第一個數(shù)開始,吧這個數(shù)與后面的數(shù)比較,如果這個數(shù)比后面的大,就交換他們的位置。
比如,第一次比較4和1,發(fā)現(xiàn)4比1大,交換 -> [1, 4, 3, 2]
第二次比較4和3,發(fā)現(xiàn)還是4大,交換 -> [1, 3, 4, 2]
第三次比較4和2,仍然4比2大,交換 -> [1, 3, 2, 4]
這樣在進行了第一輪循環(huán)之后,最大的數(shù)4就被頂?shù)綌?shù)組的最后去了,就像泡泡一樣從水底冒起來一樣。那么,要完成整個數(shù)組的排序,只需要把最大的數(shù)頂?shù)阶詈螅缓蟮诙喸侔训诙蟮臄?shù)頂?shù)降箶?shù)第二的位置,再來第三輪。。。。一直循環(huán)下去。

回到剛才的數(shù)組,第二輪比較開始,現(xiàn)在的狀態(tài)是[1, 3, 2, 4]
比較1和3,1小于3,跳過 -> [1, 3, 2, 4]
比較3和2,3大于2,交換 -> [1, 2, 3, 4]
這一輪到這里就可以停止了,因為第一輪已經(jīng)把最大的4頂?shù)搅俗詈螅缘诙喼灰_保第二大的數(shù)頂?shù)降箶?shù)第二就行。

然后繼續(xù)第三輪(雖然目前看起來已經(jīng)排序完成了)
比較1和2,不用交換[1, 2, 3, 4]
這里比較就全部完成。原理非常簡單。

?
1
2
3
4
5
6
7
8
9
def bubble_sort(list)
 list.each_index do |index|
  (list.length - index - 1).times do |e|
   if list[e] > list[e + 1]
    list[e], list[e + 1] = list[e + 1], list[e]
   end
  end
 end
end

延伸 · 閱讀

精彩推薦
  • RubyRuby進行文件信息輸出實例代碼

    Ruby進行文件信息輸出實例代碼

    Ruby進行文件信息輸出實例代碼,數(shù)據(jù)是隨機的,所以每次的記錄都會不同。 ...

    ruby教程網(wǎng)2962020-04-10
  • RubyRuby簡潔學習筆記(一):字符串、數(shù)字、類和對象

    Ruby簡潔學習筆記(一):字符串、數(shù)字、類和對象

    這篇文章主要介紹了Ruby簡潔學習筆記(一):字符串、數(shù)字、類和對象,本文是學習筆記第一篇,需要的朋友可以參考下 ...

    腳本之家2472020-04-20
  • RubyRuby迭代器的7種技巧分享

    Ruby迭代器的7種技巧分享

    這篇文章主要介紹了Ruby迭代器的7種技巧分享,Ruby中的迭代器非常人性化,本文既是講解了7個技巧也是講解了7種迭代器,需要的朋友可以參考下 ...

    腳本之家4782020-04-20
  • RubyCentOS中配置Ruby on Rails環(huán)境

    CentOS中配置Ruby on Rails環(huán)境

    經(jīng)過一個上午的折騰,終于把ROR環(huán)境在CentOS中搞定,繞了很多彎路,把文章寫下來總結一下 ...

    可樂加糖4762020-04-12
  • Ruby簡要說明Ruby中的迭代器

    簡要說明Ruby中的迭代器

    這篇文章主要介紹了Ruby中的迭代器,迭代器的概念在動態(tài)語言的編程中十分重要,文章中介紹了Ruby中的each迭代器和collect迭代器,需要的朋友可以參考下 ...

    goldensun2772020-04-25
  • Ruby剖析 Ruby 訪問控制

    剖析 Ruby 訪問控制

    前面,我們說 Ruby 沒有函數(shù),只有方法.而且實際上有不止一種方法.這一節(jié)我們介紹 訪問控制 (accesscontrols). 想想當我們在最高層而不是在一個類的定義里定義...

    ruby教程網(wǎng)3572020-04-08
  • RubyRuby設計模式編程中使用Builder建造者模式的實例

    Ruby設計模式編程中使用Builder建造者模式的實例

    這篇文章主要介紹了Ruby設計模式編程中使用Builder建造者模式的實例,建造者模式將一個復雜對象的構造與它的表示分離,使同樣的構建過程可以創(chuàng)建不同的表...

    范孝鵬2192020-05-07
  • RubyRuby環(huán)境下安裝使用bundler來管理多版本的gem

    Ruby環(huán)境下安裝使用bundler來管理多版本的gem

    這篇文章主要介紹了Ruby環(huán)境下安裝使用bundler來管理多版本的gem的方法,舉了Ruby On Rails中的應用實例來進行演示,需要的朋友可以參考下 ...

    日拱一卒4332020-05-10
主站蜘蛛池模板: 亚洲一区av在线 | 国产精品久久久爽爽爽麻豆色哟哟 | 午夜影院免费观看 | 视频一区二区国产 | 亚洲国产精品久久久久秋霞蜜臀 | 日韩av电影在线观看 | 综合久久亚洲 | 91大神免费观看 | 精品女同一区二区三区在线绯色 | 日本一区二区不卡 | 欧美成人精品在线视频 | 欧美精品一区二区三区在线 | 色av影院| 性做久久久久久 | 中文字幕啪啪 | 乳首在线| 麻豆美女| 国产精品欧美一区二区 | 国产激情在线 | 日日操日日操 | 亚洲电影专区 | 色综合一区二区三区 | 久久久综合网 | 免费观看的av | 丁香综合| 精品久久久久久久久久久久久久 | 亚洲激情一区二区三区 | 我要看黄色一级大片 | 蜜桃精品久久久久久久免费影院 | 亚洲国产精品成人 | 欧美影视一区二区三区 | 国产尤物一区 | 91国内在线观看 | 日韩欧美中文字幕一区二区三区 | 成人午夜免费视频 | 欧美一区二区三区在线观看视频 | 久久伊人中文字幕 | 亚洲三区在线观看 | 久久亚洲国产精品 | av影院在线观看 | 精品99在线 |