标签:des mat 最小花费 for stack rip ini 整数 out
12 16 2 2 2 2 2 2 2 2 2 2 2 2 1 3 3 2 2 1 3 4 2 4 3 5 5 4 4 6 6 4 7 4 7 12 7 8 8 7 8 9 10 9 11 10Sample Output
3 6
求最小点基和最小权点基稞题。
①找出图G的所有强连通分量。
②从强连通分量中找出所有的最高强连通分量。也就是缩点后入度为0的点。
③从每个最高强连通分量中任取一点,组成点集B就是一个最小点基。
从每个最高强连通分量中取权值最小的点,组成点集B就是一个最小点权基。
#include <map> #include <set> #include <cmath> #include <ctime> #include <queue> #include <stack> #include <cstdio> #include <string> #include <vector> #include <cstdlib> #include <cstring> #include <iostream> #include <algorithm> using namespace std; #define ll long long #define file(a) freopen(a".in","r",stdin); freopen(a".out","w",stdout); inline int gi() { bool b=0; int r=0; char c=getchar(); while(c<‘0‘ || c>‘9‘) { if(c==‘-‘) b=!b; c=getchar(); } while(c>=‘0‘ && c<=‘9‘) { r=r*10+c-‘0‘; c=getchar(); } if(b) return -r; return r; } const int inf = 1e9+7, N = 1007, M = 2007; int n,m,num,cnt,Deep,f[N],dfn[N],low[N],bl[N],V[N],C[N],rd[N]; bool b[N]; stack <int> s; struct data { int fr,nx,to; }da[M]; inline void add (int fr,int to) { da[++num].fr=fr, da[num].to=to, da[num].nx=f[fr], f[fr]=num; } inline void tarjan (int o) { int i,to; dfn[o]=low[o]=++Deep; s.push(o); b[o]=1; for (i=f[o]; i; i=da[i].nx) { to=da[i].to; if (!dfn[to]) tarjan (to), low[o]=min(low[o],low[to]); else if (b[to]) low[o]=min(low[o],dfn[to]); } if (low[o] == dfn[o]) { cnt++; do { to=s.top(); s.pop(); b[to]=0; bl[to]=cnt; V[cnt]=min(V[cnt],C[to]); } while(to != o); } } int main() { // file("HDU-1827"); int i,x,y; while (scanf ("%d%d",&n,&m) != EOF) { for (i=1; i<=n; i++) C[i]=gi(), V[i]=inf; for (i=1; i<=m; i++) { x=gi(), y=gi(); add (x,y); } for (i=1; i<=n; i++) if(!dfn[i]) tarjan (i); for (i=1; i<=num; i++) { x=bl[da[i].fr], y=bl[da[i].to]; if (x != y) rd[y]++; } x=0, y=0; for (i=1; i<=cnt; i++) if (!rd[i]) x++, y+=V[i]; printf ("%d %d\n",x,y); for (i=1; i<=n; i++) f[i]=C[i]=V[i]=dfn[i]=low[i]=bl[i]=0; for (i=1; i<=cnt; i++) rd[i]=0; for (i=1; i<=num; i++) da[i]={ 0,0,0 }; num=Deep=cnt=0; } return 0; }
欢迎在评论区提问质疑!
标签:des mat 最小花费 for stack rip ini 整数 out
原文地址:http://www.cnblogs.com/y142857/p/6883316.html