Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 8390 Accepted Submission(s):
4899
3 2
0 1
0 2
0 3
7 4
2 2
0 1
0 4
2 1
7 1
7 6
2 2
0 0

#include<iostream>
#include<cstring>
#include<cstdio>
#include<vector>
#include<queue>
#include<stack>
#include<algorithm>
using namespace std;
inline int read(){
int x=0,f=1;char c=getchar();
for(;!isdigit(c);c=getchar()) if(c==‘-‘) f=-1;
for(;isdigit(c);c=getchar()) x=x*10+c-‘0‘;
return x*f;
}
const int MAXN=100001;
const int INF=999999;
int N,M;
vector<int> vec[201];
int du[201];int val[201];
int dp[201][201];
int dp2[201];
void dfs(int x,int fa){
for(int i=0;i<vec[x].size();i++){
if(vec[x][i]!=fa) dfs(vec[x][i],x);
}
for(int i=1;i<=M;i++) dp[x][i]=val[x];
dp[x][0]=0;
for(int i=0;i<vec[x].size();i++){
if(vec[x][i]==fa) continue;
for(int j=M;j>=2;j--){
for(int k=1;k<j;k++)
dp[x][j]=max(dp[x][j],dp[vec[x][i]][k]+dp[x][j-k]);
}
}
return ;
}
int main(){
while(scanf("%d%d",&N,&M)!=EOF){
if(!(N+M)) break;
for(int i=1;i<=N;i++) vec[i].clear(),du[i]=0;
for(int i=1;i<=N;i++){
int a=read(),b=read();
if(a!=0) vec[a].push_back(i),du[i]++;
val[i]=b;
}
for(int i=1;i<=N;i++)
if(!du[i]) dfs(i,-1);
memset(dp2,0,sizeof(dp2));
for(int i=1;i<=N;i++){
if(du[i]) continue;
for(int j=M;j>=1;j--)
for(int k=1;k<=j;k++)
dp2[j]=max(dp2[j-k]+dp[i][k],dp2[j]);
}
printf("%d\n",dp2[M]);
}
}
原文:http://www.cnblogs.com/wxjor/p/7271958.html