前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >2022-12-18:给定一个长度为n的二维数组graph,代表一张图, graph[i] = {a,b,c,d} 表示i讨厌(a,b,c,d),讨厌关系为双向

2022-12-18:给定一个长度为n的二维数组graph,代表一张图, graph[i] = {a,b,c,d} 表示i讨厌(a,b,c,d),讨厌关系为双向

原创
作者头像
福大大架构师每日一题
发布2022-12-18 22:03:15
2410
发布2022-12-18 22:03:15
举报

2022-12-18:给定一个长度为n的二维数组graph,代表一张图,

graphi = {a,b,c,d} 表示i讨厌(a,b,c,d),讨厌关系为双向的,

一共有n个人,编号0~n-1,

讨厌的人不能一起开会。

返回所有人能不能分成两组开会。

来自微软面试。

答案2022-12-18:

力扣785。并查集。

代码用rust编写。代码如下:

代码语言:rust
复制
use rand::Rng;
use std::iter::repeat;
fn main() {
    let mut graph: Vec<Vec<i32>> = vec![vec![1, 2, 3], vec![0, 2], vec![0, 1, 3], vec![0, 2]];
    let ans = is_bipartite(&mut graph);
    println!("ans = {}", ans);
}

fn is_bipartite(graph: &mut Vec<Vec<i32>>) -> bool {
    let n = graph.len() as i32;
    let mut uf = UnionFind::new(n);
    for neighbours in graph.iter() {
        for i in 1..neighbours.len() as i32 {
            uf.union(neighbours[(i - 1) as usize], neighbours[i as usize]);
        }
    }
    for i in 0..n {
        for j in graph[i as usize].iter() {
            if uf.same(i, *j) {
                return false;
            }
        }
    }
    return true;
}

struct UnionFind {
    f: Vec<i32>,
    s: Vec<i32>,
    h: Vec<i32>,
}
impl UnionFind {
    pub fn new(n: i32) -> Self {
        let mut f: Vec<i32> = repeat(0).take(n as usize).collect();
        let mut s: Vec<i32> = repeat(0).take(n as usize).collect();
        let mut h: Vec<i32> = repeat(0).take(n as usize).collect();
        for i in 0..n {
            f[i as usize] = i;
            s[i as usize] = 1;
        }
        Self { f, s, h }
    }

    fn find(&mut self, mut i: i32) -> i32 {
        let mut hi = 0;
        while i != self.f[i as usize] {
            self.h[hi as usize] = i;
            hi += 1;
            i = self.f[i as usize];
        }
        while hi > 0 {
            hi -= 1;
            self.f[self.h[hi as usize] as usize] = i;
        }
        return i;
    }

    pub fn same(&mut self, i: i32, j: i32) -> bool {
        return self.find(i) == self.find(j);
    }

    pub fn union(&mut self, i: i32, j: i32) {
        let mut fi = self.find(i);
        let mut fj = self.find(j);
        if fi != fj {
            if self.s[fi as usize] >= self.s[fj as usize] {
                self.f[fj as usize] = fi;
                self.s[fi as usize] = self.s[fi as usize] + self.s[fj as usize];
            } else {
                self.f[fi as usize] = fj;
                self.s[fj as usize] = self.s[fi as usize] + self.s[fj as usize];
            }
        }
    }
}

执行结果如下:

在这里插入图片描述
在这里插入图片描述

左神java代码

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档