当前位置:  开发笔记 > 后端 > 正文

学习插入在Ruby中排序

如何解决《学习插入在Ruby中排序》经验,为你挑选了2个好方法。

我刚刚通过在线发布的材料开始了麻省理工学院的算法入门课程.除了课程,我还决定通过编写算法来学习/增强我的Ruby技能.

我在给出的第一个算法,即插入排序,我输入了以下代码,但是当我运行它时出现这个错误:

insertionsort.rb:5:在`>'中:Fixnum与nil的比较失败(ArgumentError)

def  insertionsort(num)
for j in 2..num.length
    key = num[j]
    i = j - 1
    while i > 0 and num[i] > key
        num[i+1] = num[i]
        i = i - 1
    end
    num[i+1] = key
end 
puts num
end

numbers = [23,34,46,87,12,1,66]

insertionsort(numbers)

我确定这是一个相当基本的问题,但我现在无法理解它是什么.任何帮助或提示将非常感谢.



1> Jeff Dallien..:

另一个答案是正确的,您将超过数组中值的结尾,因为它是基于0的,但您需要进行其他更改才能使算法工作:

for j in 1..(num.length - 1)

while i >= 0 and num[i] > key



2> Ed S...:

你正在超越数组的范围.您给出的示例是假设1索引数组,但ruby中的数组是0索引的.第一行应该是

for j in 1...num.length

推荐阅读
保佑欣疼你的芯疼
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有