結果
問題 |
No.269 見栄っ張りの募金活動
|
ユーザー |
![]() |
提出日時 | 2021-04-22 00:39:27 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
RE
|
実行時間 | - |
コード長 | 699 bytes |
コンパイル時間 | 1,474 ms |
コンパイル使用メモリ | 167,700 KB |
実行使用メモリ | 81,636 KB |
最終ジャッジ日時 | 2024-07-04 06:06:23 |
合計ジャッジ時間 | 5,940 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 RE * 1 |
other | AC * 8 WA * 2 RE * 12 |
ソースコード
#include <bits/stdc++.h> const int nn = 1000; const int kk = 20000; int dp[nn][kk]; using namespace std; long long PF(int n, int k){ if (dp[n][k] != -1) return dp[n][k]; int 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); return dp[n][k] = res; } int main(){ int N, S, K; cin >> N >> S >> K; int n = S-N*(N-1)*K/2; memset(dp, -1, sizeof(dp)); if (n>=0) cout << PF(n, N)<< endl; else cout << "0" << endl; }