【红黑图】

566 篇文章

已下架不支持订阅

472 篇文章

已下架不支持订阅

141 篇文章

已下架不支持订阅

题目解析

本题其实就是求解连通图的染色方案,

目前我想到的最好方式是暴力法,即通过回溯算法,求解出染红节点的全组合,

n个数的全组合数量一共有 (2^n) - 1。

比如:1,2,3的全组合情况有:1、2、3、12、13、23、123,即 (2^3) - 1 = 7个。

本题中节点一共有m个,而1 <= m <= 15,即最多有 (2^15) - 1 = 32767 个组合情况,这个数量级不算多。 因此暴力法可行。

我们需要尝试对组合中的节点进行染红色,但是相邻节点不能同时染成红色。因此,在求解全组合时,还可以进行剪枝优化,即判断新加入的节点  是否和 已存在的节点相邻,如果相邻,则剪枝,如果不相邻则继续递归。

// 连通图的染色方案数求解
function getDyeCount(arr, m) {
  // connect用于存放每个节点的相邻节点
  const connect = {};

  for (let [v1, v2] of arr) {
    connect[v1] ? connect[v1].add(v2) : (connect[v1] = new Set([v2]));
    connect[v2] ? connect[v2].add(v1) : (connect[v2] = new Set([v1]));
  }

  // 必有一种全黑的染色方案
  let count = 1;

  // 求解染红节点的全组合情

已下架不支持订阅

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员阿甘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值