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

首頁 > 編程 > Ruby > 正文

Ruby實現的合并排序算法

2020-10-29 19:39:11
字體:
來源:轉載
供稿:網友

算法課的作業,利用分治法,合并排序。

#encoding: utf-8#author: xu jin, 4100213#date: Oct 27, 2012#MergeSort#to sort an array by using MergeSort algorithm#example output:#The original array is:[4, 32, 84, 58, 49, 40, 75, 29, 82, 21, 70, 37, 70]#The sorted array is: [4, 21, 29, 32, 37, 40, 49, 58, 70, 70, 75, 82, 84]MAX = 100arrayInt = Array.newfor index in (0..12) arrayInt[index] = rand(100) #produce 12 random numberendputs "The original array is:" + arrayInt.to_sdef merge(arr, left, middle, right) arrL ,arrR = Array.new, Array.new arrL[0..(middle - left)], arrR[0..(right - middle - 1)] = arr[left..middle], arr[middle + 1.. right] arrL[arrL.size] ,arrR[arrR.size]= MAX, MAX for k in (left..right)  arrL.first <= arrR.first ? (arr[k] = arrL.shift) : (arr[k] = arrR.shift) endenddef merge_sort(arr, left, right) if left < right then  middle = (left + right)/2  merge_sort(arr, left, middle)  merge_sort(arr, middle + 1, right)  merge(arr, left, middle, right) endendmerge_sort(arrayInt, 0, arrayInt.length-1)puts "The sorted array is: " + arrayInt.to_s

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 赞皇县| 南陵县| 桦甸市| 商城县| 溧阳市| 承德市| 衡山县| 沧源| 准格尔旗| 南丹县| 菏泽市| 六盘水市| 巩留县| 固原市| 贡嘎县| 三原县| 宜宾县| 肥城市| 绥芬河市| 黑水县| 沁源县| 仪陇县| 镇雄县| 根河市| 南阳市| 中牟县| 太白县| 龙胜| 大余县| 金乡县| 阿瓦提县| 涿州市| 麦盖提县| 安顺市| 肃宁县| 阳春市| 乌苏市| 芷江| 滦平县| 乌苏市| 乌苏市|