結果
問題 |
No.196 典型DP (1)
|
ユーザー |
![]() |
提出日時 | 2015-07-08 17:41:23 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,097 bytes |
コンパイル時間 | 1,692 ms |
コンパイル使用メモリ | 161,128 KB |
実行使用メモリ | 26,068 KB |
最終ジャッジ日時 | 2024-07-08 01:43:41 |
合計ジャッジ時間 | 8,263 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | -- * 3 |
other | AC * 23 WA * 11 TLE * 1 -- * 6 |
ソースコード
#include<bits/stdc++.h> using namespace std; const int mod = 1000000007; int N, K; vector< int > graph[2000]; int dp[2000][2001]; int size[2000]; // SubTreeSize int dfs(int idx, int prev) { size[idx] = 1; for(int i = 0; i < graph[idx].size(); i++) { if(graph[idx][i] == prev) continue; size[idx] += dfs(graph[idx][i], idx); } return(size[idx]); } int rec(int idx, int prev, int mul) { if(~dp[idx][mul]) return(dp[idx][mul]); int* dp2 = dp[idx]; for(int i = 0; i <= K; i++) dp2[i] = 0; dp2[0] = 1; for(int i = 0; i < graph[idx].size(); i++) { if(graph[idx][i] == prev) continue; for(int j = K; j >= 0; j--) { if(dp2[j] == 0) continue; for(int k = K - j; k > 0; k--) { (dp2[j + k] += dp2[j] * rec(graph[idx][i], idx, k)) %= mod; } } } (dp2[size[idx]] += 1) %= mod; return(dp2[mul]); } int main() { fill_n(*dp, 2000 * 2001, -1); cin >> N >> K; for(int i = 0; i < N - 1; i++) { int a, b; cin >> a >> b; graph[a].push_back(b); graph[b].push_back(a); } dfs(0, -1); cout << rec(0, -1, K) << endl; }