結果
問題 |
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