洛谷 P1113 雜務(搜尋_圖論)
阿新 • • 發佈:2019-01-10
從某項工作的準備工作往該工作建邊(這裡用的vector),然後從第一個節點直接跑深搜求距離。
Code:
#include<cstdio>
#include<cstdlib>
#include<vector>
using namespace std;
int n,x,ans=0;
int d[10010],m[10010];
vector<int> f[10010];
void dfs(int x)
{
if(ans<d[x]) ans=d[x];
for(int i=0;i<f[x].size();i++)
if (d[f[x][i]]<d[x]+m[f[x][i]] && f[x][i]!=x)
{
d[f[x][i]]=d[x]+m[f[x][i]];
dfs(f[x][i]);
}
}
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
{
scanf("%*d%d",&m[i]);
while(scanf("%d",&x)&&x)
f[x].push_back(i);
}
d[1 ]=m[1];
dfs(1);
printf("%d\n",ans);
}