gem algorithms0.1.0 算法部分分析3

gem algorithms0.1.0 算法部分分析3
第三个算法较简单,是简单的选择法排序,而且思路和书上的差不多,其源码如下:
  #   Algorithms::Sort.selection_sort [5, 4, 3, 1, 2] => [1, 2, 3, 4, 5]
  def self.selection_sort(container)
    0.upto(container.size-1) do |i|
      min = i
      (i+1).upto(container.size-1) do |j|
        min = j if (container[j] <=> container[min]) == -1
      end
      container[i], container[min] = container[min], container[i] # Swap
    end
    container
  end
我都不想测试一下了。太明显。不过,min默认i是最小值,当i不是时,需要进行交换,但作者没有进行判断:
      container[i], container[min] = container[min], container[i] # Swap
反正作者的意思,当i==min时,交换等于没交换。
当i!=min时,就肯定是交换了,这种情况是一定要交换的。
最后,把交换后的数据传递出去。很漂亮,我能看懂。
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值