Description
Input
Output
#include<stdio.h>
#include<cstring>
using namespace std;
const long maxn=10001;const long INF=1;
bool flag[maxn];long cnt,i,n,j,xx,time,y,h,t,go,now,ans,tong;
long dis[maxn],begin[maxn],end[maxn],x[200*maxn];
struct arr{long l,r,s,next;}a[200*maxn];
void make_up(long l,long r,long v)
{
a[++cnt].l=l;a[cnt].r=r;a[cnt].s=-v;a[cnt].next=-1;
if (begin[l]==0) {begin[l]=cnt;end[l]=cnt;}
else {a[end[l]].next=cnt;end[l]=cnt;}
}
int main()
{
//freopen("chores.in","r",stdin);freopen("chores.out","w",stdout);
scanf("%ld",&n);
for (i=1;i<=n;i++)
{
scanf("%ld",&time);
scanf("%ld",&xx);
for (j=1;j<=xx;j++)
{
scanf("%ld",&y);
make_up(y,i,time);
}
if (xx==0) make_up(0,i,time);
}
memset(flag,0,sizeof(flag));memset(dis,INF,sizeof(dis));
h=0;t=1;x[1]=0;dis[0]=0;flag[0]=true;
while (h<t)
{
now=x[++h];if (begin[now]==0) continue;i=begin[now];
while (true)
{
go=a[i].r;
if (dis[now]+a[i].s<dis[go])
{
dis[go]=dis[now]+a[i].s;
if (!flag[go])
{
flag[go]=true;
x[++t]=go;
}
}
if (a[i].next==-1) break;i=a[i].next;
}
flag[now]=false;
}
for (i=1;i<=n;i++)
if (-dis[i]>ans) ans=-dis[i];
printf("%ld",ans);
//scanf("%ld",&n);
return 0;
}#include<stdio.h>
#include<cstring>
using namespace std;
long f[10001],n,i,j,max,ans,xx,y;
int main()
{
//freopen("chores.in","r",stdin);freopen("chores.out","w",stdout);
scanf("%ld",&n);
for (i=1;i<=n;i++)
{
scanf("%ld",&f[i]);
scanf("%ld",&xx);max=0;
for (j=1;j<=xx;j++)
{
scanf("%ld",&y);
if (f[y]>max) max=f[y];
}
f[i]+=max;
if (f[i]>ans) ans=f[i];
}
printf("%ld",ans);
//scanf("%ld",&n);
return 0;
}#include<stdio.h>
#include<cstring>
using namespace std;
const long maxn=10001;const long INF=1;
long time[maxn],dp[maxn],begin[maxn],end[maxn],cnt,j,n,i,x,y,ans;
struct arr{long l,r,next;}a[200*maxn];
void make_up(long l,long r)
{
a[++cnt].l=l;a[cnt].r=r;a[cnt].next=-1;
if (begin[l]==0) {begin[l]=cnt;end[l]=cnt;}
else {a[end[l]].next=cnt;end[l]=cnt;}
}
long go(long k)
{
if (dp[k]>0) return dp[k];
long now=begin[k];
while (now>0)
{
long temp=go(a[now].r);
dp[k]=(temp>dp[k])?temp:dp[k];
now=a[now].next;
}
dp[k]+=time[k];
return dp[k];
}
int main()
{
//freopen("chores.in","r",stdin);freopen("chores.out","w",stdout);
scanf("%ld",&n);
for (i=1;i<=n;i++)
{
scanf("%ld",&time[i]);
scanf("%ld",&x);
for (j=1;j<=x;j++)
{
scanf("%ld",&y);make_up(i,y);
}
if (x==0) dp[i]=time[i];
}
for (i=1;i<=n;i++)
{
long temp=go(i);
ans=(temp>ans)?temp:ans;
}
printf("%ld",ans);
//scanf("%ld",&n);
return 0;
}原文:http://blog.csdn.net/jiangshibiao/article/details/19684085