图算法:判断是否为二部图-js实现

文章介绍了一个JavaScript函数Bipartite_Graph(),用于判断给定的图是否为二部图。通过建立邻接矩阵表示图,并使用深度优先搜索进行遍历,检查相邻节点的标记是否一致来确定图是否具有二部性。

1. 如图

        判断左图是否为二部图。(显然是二部图,如右图所示)

 2. js代码实现

console.log(Bipartite_Graph());
// 二部图的判断算法:Bipartite Graph
function Bipartite_Graph(){
    v_num=8;
    G=new Array(v_num).fill(0).map(()=>new Array(v_num).fill(0));
    G[0][1]=1;G[0][3]=1;G[0][4]=1;G[1][0]=1;G[1][2]=1;G[1][5]=1;G[2][1]=1;G[2][3]=1;G[2][6]=1;G[3][0]=1;G[3][2]=1;G[3][7]=1;
    G[4][0]=1;G[4][5]=1;G[4][7]=1;G[5][1]=1;G[5][4]=1;G[5][6]=1;G[6][2]=1;G[6][5]=1;G[6][7]=1;G[7][3]=1;G[7][4]=1;G[7][6]=1;

    visit=new Array(v_num).fill(0);                 /* 访问标记 */
    Queue=new Array();                              /* 访问队列 */
    flag=true;                                      /* 判定符号 */

    Queue.push(0);                                  /* 起始节点入队列 */
    visit[0]=1;
    while(Queue.length>0){
        node=Queue[0];                              /* 出队列 */
        Queue.shift();  
        for(i=0;i<v_num;i++){
            if(G[node][i]==1){                      /* 判断是否有边 */
                if(visit[i]==0){                    /* 未被访问过 */
                    visit[i]=-visit[node];
                    Queue.push(i);
                }else{
                    if(visit[node]==visit[i]){      /* 已访问结点标记是否一致 */
                        flag=false;
                        break;
                    }
                }
            }
        }
        if(!flag){                                  /* 跳出循环 */
            break;
        }
    }
    return flag;
}
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值