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

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

Ruby實現插入排序算法及進階的二路插入排序代碼示例

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

基礎
將一個記錄插入到一個已經排序好的表中,以得到一個記錄增一的有序表。并且最關鍵的一點就是它把比當前元素大的記錄都往后移動,用以空出“自己”該插入的位置。當n-1趟插入完成后該記錄就是有序序列。

def insertSort(tarray)  i=1  while(i < tarray.size) do   if tarray[i] < tarray[i-1]     j=i-1     x=tarray[i]   #puts x.class   #puts tarray[i].class     tarray[i]=tarray[i-1]#先與左側第一個比自己大的交換位置     while(x< tarray[j].to_i) do#尋找到一個比自己小的,并放在其后      tarray[j+1]=tarray[j]      #puts tarray[j].class      j=j-1     end     tarray[j+1]=x   end   i=i+1  end enda=[5,2,6,4,7,9,8]insertSort(a)print a
[2, 4, 5, 6, 7, 8, 9]>Exit code: 0

剛開始寫代碼時,在x< tarray[j]處沒有加to_i方法,出現了如下錯誤:

final.rb:10:in `<': comparison of Fixnum with nil failed (ArgumentError)

一開始我很困惑,便在輸出了x.class,tarray[j].class,然而這兩的輸出都是Fixnum。后來發現,Ruby的Array類和其他的不太一樣,Ruby中允許一個Array對象中存儲不同類型的元素,當a的一個元素賦值給x后,無法確定與x比較的a[i]是否是Fixnum類型,所以報錯,這只是我自己的理解。

進階
2路插入排序基于折半插入排序:

def two_way_sort data first,final = 0,0 temp = [] temp[0] = data[0] result = [] len = data.length for i in 1..(len-1)  if data[i]>=temp[final]   final +=1   temp[final] = data[i]  elsif data[i]<= temp[first]   first = (first -1 + len)%len   temp[first] = data[i]  else   if data[i]<temp[0]    low = first    high = len -1       while low <=high do     m = (low + high)>>1     if data[i]>temp[m]      low = m + 1     else      high = m -1     end    end        j = first - 1    first -=1    while j < high do     temp[j] = temp[j+1]     j +=1    end     temp[high] = data[i]   else    low =0    high = final    while low <=high do     m =(low + high)>>1     if data[i]>=temp[m]      low = m + 1     else      high = m - 1     end    end    j = final + 1    final +=1    while j > low do     temp[j] = temp[j-1]     j -=1    end     temp[low] = data[i]   end  end   p temp  end i = 0 for j in first..(len - 1)  result[i] = temp[j]  i +=1 end for j in 0..final  result[i] = temp[j]  i +=1 end return resultenddata = [4,1,5,6,7,2,9,3,8].shufflep dataresult = two_way_sort datap result

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 雷山县| 漠河县| 栾川县| 依兰县| 嘉荫县| 绥中县| 陆良县| 波密县| 瑞丽市| 福安市| 长垣县| 棋牌| 陕西省| 阿图什市| 永安市| 石门县| 威远县| 韩城市| 思茅市| 仁布县| 罗定市| 蕉岭县| 石泉县| 广水市| 延安市| 霍山县| 麦盖提县| 湖南省| 上饶县| 高碑店市| 远安县| 石景山区| 乐业县| 边坝县| 宝丰县| 台州市| 光山县| 宜阳县| 包头市| 黑山县| 柏乡县|