結果
問題 |
No.269 見栄っ張りの募金活動
|
ユーザー |
![]() |
提出日時 | 2021-04-22 01:20:22 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
MLE
|
実行時間 | - |
コード長 | 790 bytes |
コンパイル時間 | 1,419 ms |
コンパイル使用メモリ | 167,452 KB |
実行使用メモリ | 814,660 KB |
最終ジャッジ日時 | 2024-07-04 06:08:17 |
合計ジャッジ時間 | 3,809 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | -- * 3 |
other | MLE * 1 -- * 21 |
ソースコード
#include <bits/stdc++.h> const int nn = 20001; const int kk = 20001; const long long mod = 1e9+7; int dp[nn][kk]; using namespace std; long long PF(int n, int k){ if (dp[n][k] != -1) return dp[n][k]; long long res; // P(1,2)の様なケースが来たときは n==1のケースではなく、n-k<0のケース if (n-k<0) return res = PF(n, n); else if (n==1) return res = k; else if (n==0) return res = 1; else if (k==1) return res = 1; else res = (PF(n, k-1)+ PF(n-k, k))%mod; return dp[n][k] = res%mod; } int main(){ int N, S, K; cin >> N >> S >> K; int n = S-N*(N-1)*K/2; memset(dp, -1, sizeof(dp)); if (S==0) cout << "0" << endl; else if (n>=0) cout << PF(n, N)<< endl; else cout << "0" << endl; }