1. 程式人生 > >洛谷 P1113 雜務(搜尋_圖論)

洛谷 P1113 雜務(搜尋_圖論)

傳送門

從某項工作的準備工作往該工作建邊(這裡用的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); }