当前位置: 首页 > wzjs >正文

网站建设微信官网开发热门seo推广排名稳定

网站建设微信官网开发,热门seo推广排名稳定,wordpress 页面上显示文章,各位大哥给个网站给定一组 n 人(编号为 1, 2, …, n), 我们想把每个人分进任意大小的两组。每个人都可能不喜欢其他人,那么他们不应该属于同一组。 给定整数 n 和数组 dislikes ,其中 dislikes[i] [ai, bi] ,表示不允许将…

给定一组 n 人(编号为 1, 2, …, n), 我们想把每个人分进任意大小的两组。每个人都可能不喜欢其他人,那么他们不应该属于同一组。

给定整数 n 和数组 dislikes ,其中 dislikes[i] = [ai, bi] ,表示不允许将编号为 ai 和 bi的人归入同一组。当可以用这种方法将所有人分进两组时,返回 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 <= 104
dislikes[i].length == 2
1 <= dislikes[i][j] <= n
ai < bi
dislikes 中每一组都 不同

思路:用「染色法」来解决,第一组颜色标记为 1, 则相邻组的颜色标记为 2,遍历时,如果发现邻节点已经被染色,且和当前节点的颜色相同,说明是不能划分为两组的。
可采用 dfs 和 bfs 来做

import collections
class Solution:def dfs(self, color, f, index, co):color[index] = cofor x in f[index]:## 与3做异或,要么是 1,要么是2## 注意, 这儿不能直接写  return self.dfs(color, f, x, co^3)if color[x] == 0 and not self.dfs(color, f, x, co^3):return Falseelse:  ## 和 当前进行比较,如果颜色相同, 直接返回 Falseif color[x] == co:return Falsereturn True## 转化成不能有环的问题,染色,两种颜色def possibleBipartition(self, n: int, dislikes: List[List[int]]) -> bool:if len(dislikes) == 0:return Truef = [[] for i in range(n+1)]color = [0]*(n+1)for i in range(0, len(dislikes)):x1, x2 = dislikes[i][0], dislikes[i][1]f[x1].append(x2)f[x2].append(x1)for i in range(1, n+1):if color[i] == 0:## 初始颜色设为 1, 设成 2 也 okif not self.dfs(color, f, i, 1):return Falsereturn True

bfs:

import collections
class Solution:## 转化成不能有环的问题def possibleBipartition(self, n: int, dislikes: List[List[int]]) -> bool:if len(dislikes) == 0:return True### 对已经遍历过&&并已加入 graph 的 index 做标记f = [[] for i in range(n+1)]vis = [0]*(n+1)for i in range(0, len(dislikes)):x1, x2 = dislikes[i][0], dislikes[i][1]f[x1].append(x2)f[x2].append(x1)for i in range(1, n+1):if vis[i] == 0:p = collections.deque()p.append((i, 1))while len(p) > 0:x1, color = p.popleft()vis[x1] = colornewColor = color^3for x in f[x1]:## 如果 x 没有被访问过if vis[x] == 0:p.append((x, newColor))else:  ## 否则和当前的  colr 比较if color == vis[x]:return Falsereturn True
http://www.dtcms.com/wzjs/232188.html

相关文章:

  • 手机网站策划书百度首页关键词推广
  • 网站建设方案的重要性怎么引流推广
  • 微商软件商城总站手机免费建站系统
  • 罗湖商城网站设计费用百度竞价推广开户价格
  • 做的好的电商网站项目策划方案怎么做
  • 上海制作网站的网站seo优化官网
  • 毕业生 网站开发舆情服务公司
  • 安徽省建设厅网站域名网站建设 网站制作
  • 新疆工商局网站墨子学院seo
  • 公司网站无法打开白帽seo
  • 使用wampserver做响应式网站seo优化官网
  • 购物商城模板网站关键词排名优化客服
  • 代运营套餐价格表重庆seo博客
  • 建设网站的申请信用卡分期2023疫情第三波爆发时间
  • 做网站和做网店哪个好seo实战密码在线阅读
  • 做婚庆网站有哪些seo软件优化工具软件
  • 做网站的人月软文营销文案
  • 体育新闻网站源码社群营销
  • 网站里可以添加视频做背景吗seol英文啥意思
  • 3g网站设计谷歌seo优化中文章
  • 驰业网站建设百度app下载链接
  • 虚拟主机网站空间查询域名网站
  • 做外贸比较好得网站中国纪检监察报
  • cms 政府网站 模板 div css知乎关键词搜索排名
  • 网站后台用什么语言合适广州疫情防控措施
  • 怎么做淘宝网站的网页宁波seo优化报价多少
  • 淮阴区住房和城乡建设局网站seo报价单
  • 做外贸的阿里巴巴网站是哪个更好潍坊网站建设seo
  • 做网站原型的简单工具360优化大师安卓版下载
  • 江门官网建站公司百度获客平台