def bubble_sort_by nums
do_it_again = false
nums[0...-1].each_with_index do |item, index|
if yield(nums[index], nums[index + 1]) > 0
nums[index], nums[index + 1] = nums[index + 1], nums[index]
do_it_again = true
end
end
bubble_sort_by nums if do_it_again
nums
end
bubble_sort_by(["hi","hello","hey"]) do |left,right|
right.length - left.length
end
程序根据 block 进行冒泡排序。在这种情况下, block 按长度排序。所以,我得到一个本地跳转错误。花了我一点时间,但我想通了。当我递归调用该方法时,我没有给它 block 。但我该怎么做呢?
最佳答案
传递 block 是可选的,但在这里,正如您已经了解的那样,您需要它来进行递归调用。您只需将 block 作为附加参数传递:
def bubble_sort_by nums, &comparator
# ...
bubble_sort_by nums, &comparator if do_it_again
# ...
end
关于ruby - 在ruby中递归地将 block 传递给方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26136542/