結果
問題 | No.1011 Infinite Stairs |
ユーザー |
![]() |
提出日時 | 2021-04-20 05:04:22 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 335 ms / 2,000 ms |
コード長 | 634 bytes |
コンパイル時間 | 6,531 ms |
コンパイル使用メモリ | 341,076 KB |
実行使用メモリ | 215,808 KB |
最終ジャッジ日時 | 2024-07-17 12:18:36 |
合計ジャッジ時間 | 9,514 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 24 |
ソースコード
#include <bits/stdc++.h> using namespace std; #include <boost/multiprecision/cpp_int.hpp> namespace mp=boost::multiprecision; int main(){ long long MOD=1000000007; int N,d,K; cin>>N>>d>>K; vector<vector<long long>> dp(N+1,vector<long long>(K+1,1)); for(int i=1;i<N+1;++i){ for(int j=0;j<K+1;++j){ if(j-d-1>=0){ dp[i][j]=(dp[i][j-1]+dp[i-1][j-1]-dp[i-1][j-d-1]+MOD)%MOD; }else if(j>0){ dp[i][j]=(dp[i][j-1]+dp[i-1][j-1])%MOD; }else{ dp[i][j]=0; } } } cout<<(MOD+dp[N][K]-dp[N][K-1])%MOD<<endl; }