百度之星2024初赛第二场 BD202411染色

原题再现

小度进入了一个迷宫当中,该迷宫为一个 n 个点,m 条边的无向图 ,在开始之前,你需要将每条边规定一个方向。一开始所有的点都是白色,同时小度手中有 k 种不包含白色的不同颜色颜料,小度将从 1 号点出发 ,++每次经过一个点都可以将该点的颜色染色,也可以不进行染色++ ,小度可以随时结束。现在小度想问你,++如何选定边的方向++ 才能使得结束之后,该迷宫生成的不同的迷宫颜色数目最多。在该方案下迷宫颜色数目有多少种可能,由于答案可能过大,答案对 998244353 取模。

对于任意两种迷宫颜色,如果存在一个点的颜色不同,则称该两种迷宫颜色不同。

对于任意两种选定边的方向的方案,如果存在任意一条边的方向不同,则称该两种方案不同。

题意简述

无向图给边定向,使得从1出发染色,最大化迷宫能生成的不同的迷宫颜色数(后简称"颜色数")。

题目解答

最优定向方案

我们要最大化颜色数,就要通过定向使从1出发经过的点最多,因为这样可以自由染色的点的数量就最多。

题目中给出的样例1有4种定向方案:

从1出发,我们需要最大化可以自由染色的点的数量,任何"反向"的边都是没有好处的。4种方案可以自由染色的点的数量分别为2,1,3,2,所以选择定向方案3。

对于样例2(自己构造的),按照同样的思路,我们可以确定如下图所示的最优定向方案。

通过这两个例子,我们对最优定向方案已经有了直观的感觉,即边的方向总是"远离"着起点1,而且可以自由染色的点构成一棵树。

考虑特殊的结构。

我们应该将环收尾顺次连起来(具体方向无所谓)。因为这样,经过环上任意一点,即可经过环上所有点,实现了经过更多的点的目标。

显然,对于环,我们要做缩点操作。

颜色数计算

在确定了最优定向方案之后,我们来计算颜色数。

还是先以样例1为例,根据之前的分析,我们已经确定它的最优定向方案如下图。

那是怎么得到颜色数6的呢?如下图。

对于样例2,颜色数为16,推导过程见下图。

上面两个例子中乘的"2"其实是k+1,代表每个可以自由染色的点的自由度,即"k种颜色+不染色"。比如,如果k=2,样例2中每个可以自由染色的点的自由度变为k+1=3,样例2颜色数变为57,推导过程如下图。

参考文献

官方题解

相关推荐
努力学算法的蒟蒻3 小时前
day58(1.9)——leetcode面试经典150
算法·leetcode·面试
txinyu的博客3 小时前
HTTP服务实现用户级窗口限流
开发语言·c++·分布式·网络协议·http
代码村新手3 小时前
C++-类和对象(上)
开发语言·c++
txinyu的博客4 小时前
map和unordered_map的性能对比
开发语言·数据结构·c++·算法·哈希算法·散列表
搞笑症患者4 小时前
压缩感知(Compressed Sensing, CS)
算法·最小二乘法·压缩感知·正交匹配追踪omp·迭代阈值it算法
im_AMBER4 小时前
Leetcode 101 对链表进行插入排序
数据结构·笔记·学习·算法·leetcode·排序算法
mjhcsp4 小时前
C++ 后缀数组(SA):原理、实现与应用全解析
java·开发语言·c++·后缀数组sa
hui函数4 小时前
如何解决 pip install 编译报错 ‘cl.exe’ not found(缺少 VS C++ 工具集)问题
开发语言·c++·pip
快手技术4 小时前
AAAI 2026|全面发力!快手斩获 3 篇 Oral,12 篇论文入选!
前端·后端·算法
颜酱4 小时前
前端算法必备:滑动窗口从入门到很熟练(最长/最短/计数三大类型)
前端·后端·算法