結果

問題 No.801 エレベーター
ユーザー kamojirokamojiro
提出日時 2019-03-17 22:53:42
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 642 ms / 2,000 ms
コード長 476 bytes
コンパイル時間 208 ms
コンパイル使用メモリ 82,048 KB
実行使用メモリ 228,736 KB
最終ジャッジ日時 2024-07-08 01:24:51
合計ジャッジ時間 11,930 ms
ジャッジサーバーID
(参考情報)
judge1 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 26
権限があれば一括ダウンロードができます

ソースコード

diff #

from itertools import accumulate
Q = 10**9 + 7
N, M, K = map( int, input().split())
I = [ tuple( map( int, input().split())) for _ in range(M)]
dp = [ [0]*(N+2) for _ in range(K+1)]
dp[0][1] = 1
for k in range(K):
    dp[k] = list( map( lambda x:x%Q, accumulate( dp[k])))
    for i in range(M):
        l, r = I[i]
        c = dp[k][r] - dp[k][l-1]
        dp[k+1][l] += c
        dp[k+1][r+1] -=c
    dp[k+1] = list( map( lambda x: x%Q, accumulate(dp[k+1])))
print(dp[K][N])
0