LeetCode 886. 可能的二分法(着色DFS/BFS/拓展并查集)

文章目录

    • 1. 题目
    • 2. 解题
      • 2.1 DFS
      • 2.2 BFS
      • 2.3 并查集

1. 题目

给定一组 N 人(编号为 1, 2, …, N), 我们想把每个人分进任意大小的两组。

每个人都可能不喜欢其他人,那么他们不应该属于同一组。

形式上,如果 dislikes[i] = [a, b],表示不允许将编号为 a 和 b 的人归入同一组。

当可以用这种方法将每个人分进两组时,返回 true;否则返回 false。

示例 1:
输入:N = 4, dislikes = [[1,2],[1,3],[2,4]]
输出:true
解释:group1 [1,4], group2 [2,3]示例 2:
输入:N = 3, dislikes = [[1,2],[1,3],[2,3]]
输出:false示例 3:
输入:N = 5, dislikes = [[1,2],[2,3],[3,4],[4,5],[1,5]]
输出:false提示:
1 <= N <= 2000
0 <= dislikes.length <= 10000
1 <= dislikes[i][j] <= N
dislikes[i][0] < dislikes[i][1]
对于 dislikes[i] == dislikes[j] 不存在 i != j 

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/possible-bipartition
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • 把人分成2组,组内没有自己不喜欢的人

2.1 DFS

着色法,初始颜色均为0,着色成1或者2,遇到矛盾的返回 false

class Solution {unordered_map<int,unordered_set<int>> m;bool ans = true;
public:bool possibleBipartition(int N, vector<vector<int>>& dislikes) {if(dislikes.size() <= 2) return true;vector<int> color(N+1, 0);for(auto& d : dislikes)//建图{m[d[0]].insert(d[1]);m[d[1]].insert(d[0]);}for(int i = 1; i <= N; i++){if(color[i] == 0)//未着色的{color[i] = 1;//着色为1dfs(i, 1, color);if(!ans)return false;}}return true;}void dfs(int id, int col, vector<int> &color){if(!ans) return;int nextcol = col==1 ? 2 : 1;//跟我相连的(不喜欢的人)颜色相反for(auto it = m[id].begin(); it != m[id].end(); it++){if(color[*it] == col)//颜色相同,出错ans = false;if(color[*it] == 0)//没有访问过的,继续着色{color[*it] = nextcol;dfs(*it, nextcol, color);}}}
};

528 ms 71.3 MB

2.2 BFS

  • 思路跟dfs一样,实现形式不一样而已
class Solution {unordered_map<int,unordered_set<int>> m;
public:bool possibleBipartition(int N, vector<vector<int>>& dislikes) {if(dislikes.size() <= 2) return true;vector<int> color(N+1, 0);for(auto& d : dislikes)//建图{m[d[0]].insert(d[1]);m[d[1]].insert(d[0]);}queue<int> q;int id, col = 1, nextcol, size;for(int i = 1; i <= N; i++){if(color[i] == 0)//未访问的{color[i] = 1;//着色为1col = 1;q.push(i);while(!q.empty()){size = q.size();nextcol = col==1 ? 2 : 1;//下一层颜色需要变while(size--){id = q.front();q.pop();for(auto it = m[id].begin(); it != m[id].end(); it++){	//相连的,不喜欢的,颜色不能一样if(color[*it] == col)return false;if(color[*it] == 0){color[*it] = nextcol;//没访问的,不喜欢的,颜色跟我不一样q.push(*it);}}}col = col==1? 2 : 1;//换颜色}}}return true;}
};

524 ms 70.9 MB

2.3 并查集

  • 参考 数据结构–并查集(Disjoint-Set)

类似题目:
LeetCode 684. 冗余连接(并查集)
LeetCode 990. 等式方程的可满足性(并查集)
LeetCode 959. 由斜杠划分区域(并查集)
LeetCode 1202. 交换字符串中的元素(并查集)
LeetCode 1319. 连通网络的操作次数(BFS/DFS/并查集)
程序员面试金典 - 面试题 17.07. 婴儿名字(并查集)

参考了题解区大佬们的思路

  • 把并查集大小开到2倍的N,左边是自己的颜色,右边是自己不喜欢的另一种颜色
  • 当a,b互斥时,a 与 b 对应的相反颜色 b+N 应该是一致的,进行merge(a, b+N)
  • 同理,merge(b, a+N)

在这里插入图片描述

class dsu
{vector<int> f;
public:dsu(int n){f.resize(n+1);for(int i = 0; i < n+1; ++i)f[i] = i;}void merge(int a, int b){int fa = find(a), fb = find(b);f[fa] = fb;}int find(int a)//循环+路径压缩{int origin = a;while(a != f[a])a = f[a];return f[origin] = a;//路径压缩}
};
class Solution {
public:bool possibleBipartition(int N, vector<vector<int>>& dislikes) {if(dislikes.size() <= 2) return true;dsu u(2*N+1);int a, b, da, db;for(auto& d : dislikes){a = d[0];b = d[1];da = a+N;//a的另外一种颜色db = b+N;//b的另外一种颜色if(u.find(a) == u.find(b))return false;u.merge(a,db);//a跟b互斥,那么a跟b的反是一样的颜色u.merge(b,da);//同理}return true;}
};

256 ms 39.6 MB

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/475688.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

css scale 元素不放大,列元素上的CSS 3动画“transform:scale”对chrome不起作用

我在Chrome v44中遇到一个问题,我尝试使用“transform&#xff1a;scale(1.1)”放大列项目中的图像,动画不起作用…如果我尝试使用firefox,它运行良好&#xff01;我认为问题是由于chrome,但我想知道是否有人找到了解决方法..column-wrap {columns: 3;}.column-item {backgroun…

js中如果无法获取某个html属性,例如自定义了一个dir属性,但获取总是为空,尝试换个词,因为可能什么关键词冲突了。...

js中如果无法获取某个html属性&#xff0c;例如自定义了一个dir属性&#xff0c;但获取总是为空&#xff0c;尝试换个词&#xff0c;因为可能什么关键词冲突了。转载于:https://www.cnblogs.com/kenkofox/archive/2011/03/26/1996416.html

LeetCode 685. 冗余连接 II(并查集)

1. 题目 在本问题中&#xff0c;有根树指满足以下条件的有向图。该树只有一个根节点&#xff0c;所有其他节点都是该根节点的后继。 每一个节点只有一个父节点&#xff0c;除了根节点没有父节点。 输入一个有向图&#xff0c;该图由一个有着N个节点 (节点值不重复1, 2, …, N…

prototype.js ajax.request,javascript – Prototype和Ajax.Request范围

我在原型的Ajax.Request类中获取正确的范围时遇到了麻烦.我要做的是编写一个包含ajax请求的简单API&#xff1a;API Class.create({initialize:function(api_token){this.api_token api_token;this.request_uri new Template(/api/#{api_token}/#{resource}.json);this.stat…

红黑树的c++完整实现源码

红黑树的c完整实现源码 作者&#xff1a;July、saturnman。时间&#xff1a;二零一一年三月二十九日。出处&#xff1a;http://blog.csdn.net/v_JULY_v。声明&#xff1a;版权所有&#xff0c;侵权必究。------------------------------------------- 前言&#xff1a; 本人…

[Kesci] 新人赛 · 员工满意度预测

文章目录1. 导入工具包2. 读取数据3. 特征处理3.1 数字特征归一化3.2 文字特征处理3.3 特征合并4. 定义模型训练5. 预测6. 新人赛结果竞赛地址 使用 sklearn Pipeline 模板 1. 导入工具包 %matplotlib inline import numpy as np import matplotlib.pyplot as plt plt.rcPar…

webusercontrol ajax,ASP.NET页面使用AjaxPro2完成JS调用后台方法

一、首先下载AjaxPro.2.dll(附下载地址)百度网盘链接&#xff1a;https://pan.baidu.com/s/1r87DE1Tza9F4NbJwTCS1AQ提取码&#xff1a;10p6二、在Visual studio中创建空Web项目&#xff0c;并将AjaxPro.2.dll复制到bin目录下&#xff0c;包括在项目中三、打开Web.config文件&a…

LeetCode 1109. 航班预订统计(差分思想)

1. 题目 这里有 n 个航班&#xff0c;它们分别从 1 到 n 进行编号。 我们这儿有一份航班预订表&#xff0c;表中第 i 条预订记录 bookings[i] [i, j, k] 意味着我们在从 i 到 j 的每个航班上预订了 k 个座位。 请你返回一个长度为 n 的数组 answer&#xff0c;按航班编号顺…

ajax点击事件无法触发,解决jQuery Ajax动态新增节点无法触发点击事件的问题_婳祎_前端开发者...

在写ajax加载数据的时候发现&#xff0c;后面添加进来的demo节点元素&#xff0c;失去了之前的点击事件。为什么点击事件失效&#xff0c;我们该怎么去解决呢?其实最简单的方法就是直接在标签中写οnclick””&#xff0c;但是这样写其实是有点low的&#xff0c;最好的方式还是…

OSS音频编程概述(DSP部分)

一、 音频概念 音频信号是一种连续变化的模拟信号&#xff0c;但计算机只能处理和记录二进制的数字信号&#xff0c;由自然音源得到的音频信号必须经过一定的变换&#xff0c;成为数字音频信号之后&#xff0c;才能送到计算机中作进一步的处理。 对于OSS编程来说&#xff0c;需…

LeetCode 853. 车队(排序)

1. 题目 N 辆车沿着一条车道驶向位于 target 英里之外的共同目的地。 每辆车 i 以恒定的速度 speed[i] &#xff08;英里/小时&#xff09;&#xff0c;从初始位置 position[i] &#xff08;英里&#xff09; 沿车道驶向目的地。 一辆车永远不会超过前面的另一辆车&#xff…

测试服务器性能常用算法,服务器性能剖析(profiling)之——简介

性能剖析(profiling)是专注于测量服务器时间花费在哪里的一种技术&#xff0c;这里“性能即响应时间”。测量是一项很有挑战性的工作&#xff0c;并且分析结果也同样有挑战性&#xff0c;测出时间花在哪里&#xff0c;和知道为什么花在那里是两码事……性能剖析一般有两个步骤&…

LeetCode 815. 公交路线(最少换乘,BFS)

1. 题目 我们有一系列公交路线。每一条路线 routes[i] 上都有一辆公交车在上面循环行驶。 例如&#xff0c;有一条路线 routes[0] [1, 5, 7]&#xff0c;表示第一辆 (下标为0) 公交车会一直按照 1->5->7->1->5->7->1->… 的车站路线行驶。 假设我们从 …

王者荣耀8月15日服务器维护,王者荣耀8月15日更新维护到什么时候 王者荣耀8月15日更新时间分享...

《王者荣耀》5V5英雄公平对战手游&#xff0c;腾讯最新MOBA大作&#xff01;5V5、3v3、1v1&#xff0c;多样模式一键体验&#xff0c;海量英雄随心选择&#xff01;10秒实时跨区匹配&#xff0c;与好友组队...类型&#xff1a;动作冒险大小&#xff1a;792.06M语言&#xff1a;…

第五章 基元类型、引用类型、值类型 CLR学习第五课

一、基元类型&#xff1a;编译器直接支持的数据类型称为基元类型&#xff08;如int类型其对于的是system。int32&#xff09;。二、类型溢出&#xff0c;可以用checked 和unchecked进行类型溢出检查和不进行类型溢出检查。一个奇怪的问题&#xff0c;2个byte类型相加的结果居然…

LeetCode 640. 求解方程(字符串)

1. 题目 求解一个给定的方程&#xff0c;将x以字符串"x#value"的形式返回。该方程仅包含’’&#xff0c;’ - 操作&#xff0c;变量 x 和其对应系数。 如果方程没有解&#xff0c;请返回“No solution”。 如果方程有无限解&#xff0c;则返回“Infinite solutio…

幻侠修仙服务器维护,幻侠修仙常见问题_幻侠修仙问答_疑难解答_九游手机游戏...

幻侠修仙官网安卓正式版带来震撼无限的修仙剧情模式&#xff0c;让你去体验无尽的冒险传说&#xff0c;带来真实的玄幻与小说的经典模式&#xff0c;还有特节等你还原出来&#xff1b;经历五行天劫的磨炼&#xff0c;我们的修仙之路一日千里&#xff0c;在挂机战斗的逍遥路途之…

LeetCode 84. 柱状图中最大的矩形(单调递增栈)

文章目录1. 题目2. 解题1. 题目 题目链接 给定 n 个非负整数&#xff0c;用来表示柱状图中各个柱子的高度。每个柱子彼此相邻&#xff0c;且宽度为 1 。 求在该柱状图中&#xff0c;能够勾勒出来的矩形的最大面积。 以上是柱状图的示例&#xff0c;其中每个柱子的宽度为 1&am…

option

The Tk command option acts on the "option database". [option add] pattern value ?priority? [option clear] option get window name class [option readfile] fileName ?priority?转载于:https://www.cnblogs.com/greencolor/archive/2011/04/10/…

LeetCode 30. 串联所有单词的子串(字符串哈希)

1. 题目 给定一个字符串 s 和一些长度相同的单词 words。找出 s 中恰好可以由 words 中所有单词串联形成的子串的起始位置。 注意子串要与 words 中的单词完全匹配&#xff0c;中间不能有其他字符&#xff0c;但不需要考虑 words 中单词串联的顺序。 示例 1&#xff1a; 输入…