标签:
6 7
1 2
2 3
3 5
2 4
4 1
2 6
6 5
10
12
8
16
1
5
1 4
4 3 5 6
47
思路:
1、分析路可以重复走,想到强连通分量,如果强连通分量里面有一个点被访问,那么整个强连通分量都要被访问,否则答案偏小,于是先tarjan再缩点
2、缩点之后,整个图由一个有向有环图变为一个有向无环图,于是spfa处理,然后就AC了(bzoj上的好像能卡掉,WYW用tarjan写信息传递好像被卡了)
代码:
#include<iostream> #include<cstdio> #include<string> #include<cstring> #include<vector> #include<algorithm> #include<queue> #include<stack> #define maxn 3005 #define maxint ~0U>>1 using namespace std; stack<int> sta; vector<int> comp[maxn]; int incomp[maxn],instack[maxn],dfn[maxn],low[maxn]; int index,cnum; int n,m,q,d[maxn],rice[maxn],noodle[maxn],v[maxn],s,p,ans; vector<int> g[maxn],nowg[maxn]; int nowrice[maxn],nownoodle[maxn],nows; void input(){ cin>>n>>m; int u,v; for(int i = 1;i <= m;i++){ scanf("%d%d",&u,&v); g[u].push_back(v); } for(int i = 1;i <= n;i++){ scanf("%d",&rice[i]); } cin>>s>>p; int nnow; for(int i = 1;i <= p;i++){ scanf("%d",&nnow); noodle[nnow] = 1; } } void tarjan(int u){ instack[u] = 2; dfn[u] = low[u] = ++index; sta.push(u); for(int i = 0;i < g[u].size();i++){ int j = g[u][i]; if(!dfn[j]){ tarjan(j); low[u] = min(low[u],low[j]); }else if(instack[j] == 2){ low[u] = min(low[u],dfn[j]); } } if(dfn[u] == low[u]){ ++cnum; while(!sta.empty()){ int t = sta.top(); sta.pop(); instack[t] = 1; incomp[t] = cnum; comp[cnum].push_back(t); if(t == u){ break; } } } } void work(){ for(int i = 1;i <= n;i++){ if(!dfn[i]) tarjan(i); } int u,v,newu,newv; for(int i = 1;i <= n;i++){ u = i; newu = incomp[u]; nowrice[newu] += rice[u]; if(noodle[u]) nownoodle[newu] = 1; if(u == s) nows = newu; for(int j = 0;j < g[u].size();j++){ v = g[u][j]; newv = incomp[v]; if(newu == newv) continue; nowg[newu].push_back(newv); } } } void spfa(){ queue<int> q; d[nows] = nowrice[nows]; v[nows] = 1; q.push(nows); int xx,dd,to,wei; while(!q.empty()){ xx = q.front(); dd = d[xx]; q.pop(); v[xx] = 0; if(nownoodle[xx]) ans = max(ans,dd); for(int i = 0;i < nowg[xx].size();i++){ to = nowg[xx][i]; wei = nowrice[to]; if(dd + wei > d[to]){ d[to] = dd + wei; if(!v[to]){ v[to] = 1; q.push(to); } } } } cout<<ans; } int main(){ input(); work(); spfa(); return 0; }
Tyvj1139 向远方奔跑(APIO 2009 抢掠计划)
标签:
原文地址:http://www.cnblogs.com/hyfer/p/5812614.html