国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Ruby實現的各種排序算法

2019-10-26 19:26:59
字體:
來源:轉載
供稿:網友

時間復雜度:Θ(n^2)

Bubble sort
代碼如下:
def bubble_sort(a) 
  (a.size-2).downto(0) do |i| 
    (0..i).each do |j| 
      a[j], a[j+1] = a[j+1], a[j] if a[j] > a[j+1] 
    end 
  end 
  return a 
end

Selection sort
代碼如下:
def selection_sort(a) 
  b = [] 
  a.size.times do |i| 
    min = a.min 
    b << min 
    a.delete_at(a.index(min)) 
  end 
  return b 
end

Insertion sort
代碼如下:
def insertion_sort(a) 
  a.each_with_index do |el,i| 
    j = i - 1 
      while j >= 0 
        break if a[j] <= el 
        a[j + 1] = a[j] 
        j -= 1 
      end 
    a[j + 1] = el 
  end 
  return a 
end 

 Shell sort
  代碼如下:
def shell_sort(a) 
  gap = a.size 
  while(gap > 1) 
    gap = gap / 2 
    (gap..a.size-1).each do |i| 
      j = i 
      while(j > 0) 
        a[j], a[j-gap] = a[j-gap], a[j] if a[j] <= a[j-gap] 
        j = j - gap 
      end 
    end 
  end 
  return a 
end

時間復雜度:Θ(n*logn)

Merge sort
代碼如下:
def merge(l, r) 
  result = [] 
  while l.size > 0 and r.size > 0 do 
    if l.first < r.first 
      result << l.shift 
    else 
      result << r.shift 
    end 
  end 
  if l.size > 0 
    result += l 
  end 
  if r.size > 0 
    result += r 
  end 
  return result 
end 
 
def merge_sort(a) 
  return a if a.size <= 1 
  middle = a.size / 2 
  left = merge_sort(a[0, middle]) 
  right = merge_sort(a[middle, a.size - middle]) 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 略阳县| 桐乡市| 晋城| 阜康市| 杭锦旗| 麻江县| 铜陵市| 改则县| 沂水县| 比如县| 平定县| 元朗区| 锡林郭勒盟| 西盟| 廊坊市| 常宁市| 光泽县| 鸡东县| 玉门市| 临高县| 湄潭县| 嘉定区| 湖州市| 通山县| 兴业县| 黄平县| 郸城县| 天津市| 伊金霍洛旗| 鄂托克前旗| 绿春县| 辛集市| 望城县| 吴川市| 拉萨市| 蒙山县| 广平县| 扶沟县| 南郑县| 红安县| 马公市|