国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

求無向連通圖的割點和割邊/橋

2019-11-08 19:52:16
字體:
來源:轉載
供稿:網友

代碼直接整合了求割點和割邊:

//求無向連通圖的割點和割邊/橋#include <cstdio>#include <cstring>#include <iostream>using namespace std;#define MAXN 1000#define MAXM 10000struct node{	int to;	int next;}edge[MAXM];int head[MAXN];int cnt;int n,m;int index;//時間戳int cut[MAXN];//存割點int bridge[MAXN][MAXN];//存割邊int dfn[MAXN],low[MAXN];//dfn:時間戳;low:可以到達的 訪問時間最早的 祖先(訪問時間比自己早的節點看作自己的祖先)void Init(){	cnt=0;	index=0;	memset(head,0,sizeof(head));	memset(edge,0,sizeof(edge));	memset(cut,0,sizeof(cut));	memset(bridge,0,sizeof(int)*MAXN*MAXN);	memset(dfn,0,sizeof(dfn));}void Add(int x,int y){	cnt++;	edge[cnt].to=y;	edge[cnt].next=head[x];	head[x]=cnt;}void cut_bridge(int cur,int father){	int child=0;	index++;	dfn[cur]=index;	low[cur]=index;	for(int i=head[cur];i;i=edge[i].next){		if(dfn[edge[i].to]&&edge[i].to!=father){			if(dfn[edge[i].to]<low[cur]){				low[cur]=dfn[edge[i].to];			}		}		if(!dfn[edge[i].to]){			cut_bridge(edge[i].to,cur);//可以看出,具體搜索的過程還是下一步走未訪問的點			child++;			if(low[edge[i].to]<low[cur]){				low[cur]=low[edge[i].to];			}			if((father==0&&child>1)||(father!=0&&low[edge[i].to]>=dfn[cur])){				cut[cur]=1;			}			if(low[edge[i].to]>dfn[cur]){				bridge[cur][edge[i].to]=bridge[edge[i].to][cur]=1;			}		}	}}int main(){	int x,y;	freopen("1.txt","r",stdin);	cin>>n>>m;	Init();	for(int i=1;i<=m;i++){		cin>>x>>y;		Add(x,y);		Add(y,x);	}	cut_bridge(1,0);	return 0;}對于非連通圖,對于每個連通分量取一個點調用cut_bridge()函數即可


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 达拉特旗| 宁晋县| 霍山县| 蓝山县| 龙岩市| 伊川县| 海丰县| 石首市| 砚山县| 南和县| 永城市| 锡林浩特市| 拉萨市| 宁明县| 田东县| 太和县| 永昌县| 荔浦县| 邯郸县| 黄冈市| 嵊州市| 宣威市| 大同市| 吴川市| 留坝县| 东光县| 梁山县| 曲水县| 全南县| 乌海市| 青浦区| 都安| 上思县| 杂多县| 巍山| 九寨沟县| 兴化市| 太仓市| 东台市| 宁国市| 无极县|