无向图关键点(dfs邻接阵),割点

#define MAXN 110

 

void search(int n,intmat[][MAXN],int* dfn,int* low,int now,int& ret,int* key,int& cnt,introot,int& rd,int* bb){

       int i;

       dfn[now]=low[now]=++cnt;

       for(i=0;i<n;i++)

              if(mat[now][i]){

                     if(!dfn[i]){

                            search(n,mat,dfn,low,i,ret,key,cnt,root,rd,bb);

                            if(low[i]<low[now])

                                   low[now]=low[i];

                            if(low[i]>=dfn[now]){

                                   if(now!=root&&!bb[now])

                                          key[ret++]=now,bb[now]=1;

                                   elseif(now==root)

                                          rd++;

                            }

                     }

                     elseif (dfn[i]<low[now])

                            low[now]=dfn[i];

              }

}

 

int key_vertex(int n,int mat[][MAXN],int* key){//进行值传递时,只要把数组名传递就好

       intret=0,i,cnt,rd,dfn[MAXN],low[MAXN],bb[MAXN];

       for(i=0;i<n;dfn[i++]=bb[i]=0);

       for(cnt=i=0;i<n;i++)

              if(!dfn[i]){

                     rd=0;

                     search(n,mat,dfn,low,i,ret,key,cnt,i,rd,bb);

                     if(rd>1&&!bb[i])

                            key[ret++]=i,bb[i]=1;

              }

       returnret;

}

Note:这里数组都是从0开始计数的,具体题目中可能是用1开始计数,适当调整poj1144
 


poj1144题啊,就是因为数组的下界问题,调了一个晚上,真想骂人了~~

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值