python 实现DFS判断是否是二分图Bipartite算法

DFS(深度优先搜索)算法可以用来判断一个图是否为二分图。在图论中,二分图是指一个图的所有节点可以分成两个不相交的集合,使得同一集合中的节点不相连。使用DFS算法判断二分图的基本思想是:从图中任一节点开始,尝试将节点染成两种颜色之一(通常是0和1),并递归地对每个节点的相邻节点进行染色,确保相邻节点颜色不同。如果在染色的过程中发现某个节点已经被染上了与当前应染颜色相同的颜色,则说明该图不是二分图。

以下是DFS算法判断二分图的详细步骤和关键点:

初始化:

创建一个数组colors,用于记录每个节点的颜色,初始时所有节点的颜色设为未定义(如-1)。

创建一个访问数组visited,用于记录节点是否被访问过,初始时所有节点都未被访问。

DFS函数:

输入参数包括当前节点v、当前颜色c(0或1)、图的表示graph(如邻接表)。

将当前节点v的颜色设为c,并标记为已访问。

遍历当前节点v的所有邻接节点w:

如果w未被访问,则递归调用DFS函数,将w染成与v相反的颜色(如果v是0,则w是1,反之亦然)。

如果w已被访问且颜色与v相同,则说明图不是二分图,返回失败。

主函数:

遍历图中的每个节点,如果节点未被访问,则调用DFS函数开始染色过程。

如果在DFS过程中没有返回失败,则说明图是二分图。

以下是DFS判断二分图的伪代码示例:

python 复制代码
def dfs(graph, v, color, colors, visited):
    colors[v] = color
    visited[v] = True
    for neighbor in graph[v]:
        if not visited[neighbor]:
            if not dfs(graph, neighbor, 1 - color, colors, visited):
                return False
        elif colors[neighbor] == color:
            return False
    return True

def isBipartite(graph):
    V = len(graph)
    colors = [-1] * V
    visited = [False] * V

    for i in range(V):
        if not visited[i] and not dfs(graph, i, 0, colors, visited):
            return False
    return True

注意:在实际编程中,图的表示方式(如邻接表、邻接矩阵等)和具体的DFS实现可能有所不同,但基本思路是一致的。

另外,需要注意的是,DFS算法的时间复杂度是O(V+E),其中V是节点数,E是边数,因为它需要访问图中的每个节点和每条边。## DFS判断是否是二分图Bipartite算法

DFS判断是否是二分图Bipartite算法python实现样例

以下是使用DFS判断是否是二分图的算法实现:

python 复制代码
def is_bipartite(graph):
    n = len(graph)
    color = [-1] * n

    def dfs(node, c):
        color[node] = c
        for neighbor in graph[node]:
            if color[neighbor] == c:
                return False
            if color[neighbor] == -1 and not dfs(neighbor, 1 - c):
                return False
        return True

    for i in range(n):
        if color[i] == -1:
            if not dfs(i, 0):
                return False
    return True


# 测试样例
graph = [[1, 3], [0, 2], [1, 3], [0, 2]]
print(is_bipartite(graph))  # 输出True

graph = [[1, 2, 3], [0, 2], [0, 1, 3], [0, 2]]
print(is_bipartite(graph))  # 输出False

该算法使用DFS遍历图中的每个节点,并为每个节点赋予一个颜色值,如果在DFS过程中发现两个相邻节点拥有相同的颜色,则表示图不是二分图,否则是二分图。

相关推荐
我是华为OD~HR~栗栗呀8 分钟前
华为od-21届考研-C++面经
java·c语言·c++·python·华为od·华为·面试
明月(Alioo)16 分钟前
机器学习入门,无监督学习之K-Means聚类算法完全指南:面向Java开发者的Python实现详解
python·算法·机器学习
叶梅树18 分钟前
从零构建A股量化交易工具:基于Qlib的全栈系统指南
前端·后端·算法
鱼鱼说测试32 分钟前
Linux下运行Jmeter
开发语言·python
lingran__33 分钟前
算法沉淀第三天(统计二进制中1的个数 两个整数二进制位不同个数)
c++·算法
MicroTech20251 小时前
微算法科技MLGO推出隐私感知联合DNN模型部署和分区优化技术,开启协作边缘推理新时代
科技·算法·dnn
小冯记录编程1 小时前
深入解析C++ for循环原理
开发语言·c++·算法
CodeCraft Studio1 小时前
国产化Excel开发组件Spire.XLS教程:将Python列表转换为Excel表格(3种实用场景)
开发语言·python·excel·spire.xls·python列表转excel·国产化文档开发
企鹅侠客2 小时前
基于python写的PDF表格提取到excel文档
python·pdf·excel·pdf文档表格转excel
mortimer2 小时前
Python 中那些鲜为人知但实用的工具函数
python