破坏的迭代器代码

mac*_*ean 0 ruby

跑步score([1,1,1,1])应该导致1100,但我得到了1000,我不知道为什么.我希望rubyist可以看看它,让我知道出了什么问题.我有这个代码设置一个特定的方式,因为它必须通过除此之外的其他测试.这是代码:

def score(dice)
  score = 0
  done_nos = []
  dice.each do |die|
    unless done_nos.include?(die)
        if dice.to_s.scan(/#{die}/).length >= 3
          score += 
            if die == 1
              1000
            else
              (100 * die.to_i)
            end
          if die == (5 || 1)
            score += ((dice.to_s.scan(/#{die}/).length - 3) * 
                if die == 5
                  50
                else
                  100
                end
              )
          end
        elsif die == 1
          score += (dice.to_s.scan(/#{die}/).length * 100)
        elsif die == 5 
          score += (dice.to_s.scan(/#{die}/).length * 50)
        end
    done_nos << die
    end
  end
score
end
Run Code Online (Sandbox Code Playgroud)

tyb*_*103 5

这是一个单一方法中的很多逻辑.最好将这种逻辑分解为几种较小的方法.这将使您的代码更容易测试 - 使用自动单元测试,或者只是在编写代码时.

那就是说,问题在于:

if die == (5 || 1)
Run Code Online (Sandbox Code Playgroud)

......非常怀疑你做的是你认为的那样.将其更改为:

if die == 5 || die == 1
# or
if [5, 1].include? die
Run Code Online (Sandbox Code Playgroud)