国产探花免费观看_亚洲丰满少妇自慰呻吟_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()函數即可


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 南靖县| 曲水县| 黎城县| 永宁县| 靖边县| 绥芬河市| 桐庐县| 北票市| 安仁县| 漳浦县| 大宁县| 礼泉县| 吴江市| 罗定市| 上蔡县| 法库县| 富宁县| 托里县| 呼图壁县| 尼勒克县| 富源县| 泸溪县| 将乐县| 浠水县| 扎兰屯市| 宁远县| 连州市| 孟连| 剑河县| 南宫市| 奉化市| 涿鹿县| 乌拉特前旗| 德惠市| 隆化县| 台前县| 舟曲县| 玉树县| 蓝山县| 富源县| 邢台县|