結果
| 問題 | No.260 世界のなんとか3 |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2017-01-12 00:39:02 |
| 言語 | Ruby (3.4.1) |
| 結果 |
RE
|
| 実行時間 | - |
| コード長 | 1,152 bytes |
| 記録 | |
| コンパイル時間 | 247 ms |
| コンパイル使用メモリ | 7,552 KB |
| 実行使用メモリ | 12,544 KB |
| 最終ジャッジ日時 | 2024-12-21 09:58:03 |
| 合計ジャッジ時間 | 3,944 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | RE * 3 |
| other | RE * 27 |
コンパイルメッセージ
Syntax OK
ソースコード
a, b = gets.split.map &:to_i
$mod = 10 ** 9 + 7
# http://kmjp.hatenablog.jp/entry/2015/08/03/0930
def solve(x)
dp = Array.new(n + 1).map{|_|
Array.new(2).map{|_|
Array.new(2).map{|_|
Array.new(3).map{|_|
Array.new(8, 0)}}}}
dp[0][0][0][0][0] = 1
xs = x.to_s
n = xs.size
(0 ... n).each {|d|
vd = xs[d].ord - 48
(0..1).each {|more|
(0..1).each {|i3|
(0..2).each {|m3|
(0..7).each {|m8|
(0..9).each {|x|
if more == 0 && x > vd
next
end
dp[d+1][more | (x<vd ? 1 : 0)][i3 | (x==3 ? 1 : 0)][(m3*10+x)%3][(m8*10+x)%8] += dp[d][more][i3][m3][m8]
dp[d+1][more | (x<vd ? 1 : 0)][i3 | (x==3 ? 1 : 0)][(m3*10+x)%3][(m8*10+x)%8] %= $mod # =
}
}
}
}
}
}
ret = 0
(0..1).each {|more|
(0..1).each {|i3|
(0..2).each {|m3|
(0..7).each {|m8|
if (m3 == 0 || i3 == 1) && m8 != 0
ret += dp[n][more][i3][m3][m8]
ret %= $mod #=
end
}
}
}
}
ret
end
puts (solve(b) - solve(a - 1) + $mod) % $mod