結果
問題 | No.129 お年玉(2) |
ユーザー |
![]() |
提出日時 | 2018-03-15 21:10:10 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 449 ms / 5,000 ms |
コード長 | 670 bytes |
コンパイル時間 | 638 ms |
コンパイル使用メモリ | 56,040 KB |
実行使用メモリ | 394,752 KB |
最終ジャッジ日時 | 2024-11-28 01:02:26 |
合計ジャッジ時間 | 12,403 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 46 |
ソースコード
#include<iostream> using namespace std; const int mod = 1000000000; int dp[10001][10000]; int c_dp(int n,int r){ if(dp[n][r] != -1) return dp[n][r]; if(n < 2*r) return c_dp(n,n-r); if(r == 0){ dp[n][r] = 1; return 1; } if(r == 1){ dp[n][r] = n; return n; } else{ dp[n][r] = (c_dp(n-1,r-1)+c_dp(n-1,r))%mod; return dp[n][r]; } } int main(){ long long N; int M,r,ans; cin >> N >> M; N /= 1000; r = N%M; for(int i=0;i<10001;i++){ for(int j=0;j<10000;j++){ dp[i][j] = -1; } } ans = c_dp(M,r); cout << ans << endl; return 0; }