力扣labuladong——一刷day79

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • [一、力扣785. 判断二分图](#一、力扣785. 判断二分图)
  • [二、力扣886. 可能的二分法](#二、力扣886. 可能的二分法)

前言


给你一幅「图」,请你用两种颜色将图中的所有顶点着色,且使得任意一条边的两个端点的颜色都不相同,你能做到吗? 这就是图的「双色问题」,其实这个问题就等同于二分图的判定问题,如果你能够成功地将图染色,那么这幅图就是一幅二分图,反之则不是:

一、力扣785. 判断二分图

java 复制代码
class Solution {
    boolean ok = true;
    boolean[] visited;
    boolean[] color;
    public boolean isBipartite(int[][] graph) {
        int n = graph.length;
        visited = new boolean[n];
        color = new boolean[n];
        for(int i = 0; i < n; i ++){
            if(!visited[i]){
                traverse(graph, i);
            }
        }
        return ok;
    }
    public void traverse(int[][] graph, int v){
        if(!ok){
            return;
        }
        visited[v] = true;
        for(int e : graph[v]){
            if(!visited[e]){
                color[e] = !color[v];
                traverse(graph,e);
            }else{
                if(color[e] == color[v]){
                    ok = false;
                    return;
                }
            }
        }
    }
}

二、力扣886. 可能的二分法

java 复制代码
class Solution {
    boolean ok = true;
    boolean[] visited;
    boolean[] color;
    public boolean possibleBipartition(int n, int[][] dislikes) {
        visited = new boolean[n];
        color = new boolean[n];
        List<Integer>[] graph = builderGraph(dislikes, n);
        for(int i = 0; i < n; i ++){
            if(!visited[i]){
                BFS(graph, i);
            }
        }
        return ok;
    }
    public List<Integer>[] builderGraph(int[][] dislikes,int n){
        List<Integer>[] graph = new LinkedList[n];
        for(int i = 0; i < n ; i ++){
            graph[i] = new LinkedList<>();
        }
        for(int[] arr : dislikes){
            int to = arr[0]-1;
            int from = arr[1]-1;
            graph[to].add(from);
            graph[from].add(to);
        }
        return graph;
    }
    public void BFS(List<Integer>[] graph, int v){
        if(!ok){
            return;
        }
        Deque<Integer> deq = new LinkedList<>();
        deq.offerLast(v);
        visited[v] = true;
        while(!deq.isEmpty()){
            int cur = deq.pollFirst();
            for(int e : graph[cur]){
                if(!visited[e]){
                    visited[e] = true;
                    color[e] = !color[cur];
                    deq.offerLast(e);
                }else{
                    if(color[e] == color[cur]){
                        ok = false;
                        return;
                    }
                }
            }
        }
    }
}
相关推荐
laplace012337 分钟前
Java八股—MySQL
java·mysql·oracle
熙客2 小时前
TiDB:分布式关系型数据库
java·数据库·分布式·tidb
你想考研啊3 小时前
linux安装jdk和tomcat和并自启动
java·linux·tomcat
智驱力人工智能4 小时前
基于视觉分析的人脸联动使用手机检测系统 智能安全管理新突破 人脸与手机行为联动检测 多模态融合人脸与手机行为分析模型
算法·安全·目标检测·计算机视觉·智能手机·视觉检测·边缘计算
悟能不能悟5 小时前
java的java.sql.Date和java.util.Date的区别,应该怎么使用
java·开发语言
2301_764441335 小时前
水星热演化核幔耦合数值模拟
python·算法·数学建模
循环过三天5 小时前
3.4、Python-集合
开发语言·笔记·python·学习·算法
高山上有一只小老虎6 小时前
java 正则表达式大全
java·正则表达式
_院长大人_6 小时前
设计模式-工厂模式
java·开发语言·设计模式
凌波粒7 小时前
MyBatis完整教程IDEA版(2)--ResultMap/注解/一对多/多对一/lombok/log4j
java·intellij-idea·mybatis