結果
| 問題 | No.260 世界のなんとか3 |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2017-01-12 00:39:26 |
| 言語 | Ruby (3.4.1) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 1,152 bytes |
| 記録 | |
| コンパイル時間 | 72 ms |
| コンパイル使用メモリ | 7,424 KB |
| 実行使用メモリ | 40,704 KB |
| 最終ジャッジ日時 | 2024-12-21 09:59:17 |
| 合計ジャッジ時間 | 69,646 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 6 TLE * 21 |
コンパイルメッセージ
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)
xs = x.to_s
n = xs.size
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
(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