Solution -「多校联训」签到题
\(\mathcal{Description}\)
Link.
给定二分图 \(G=(X\cup Y,E)\),求对于边的一个染色 \(f:E\rightarrow\{1,2,\dots,c\}\),最小化每个结点所染颜色数量极差之和。输出这一最小值。
\(|X|+|Y|,|E|\le10^6\)。
\(\mathcal{Solution}\)
基于“结论好猜”就能认为这题是签到题吗……
答案显然有下界 \(\sum_{u}\left[c\not\mid \sum_{v}[(u,v)\in E]\right]\)。由于写一发过掉了大样例,我们尝试证明它必然可取到。
证明
**引理(对于二分图的 Vizing 定理):** 对于二分图 $G$,$\chi'(G)=\Delta(G)$,其中 $\chi'(G)$ 为 $G$ 的边染色的色数,$\Delta(G)$ 为 $G$ 中结点的最大度数。
证明: 给出构造。按任意顺序枚举 \((x,y)\in E\),令 \(p\) 为 \(x\) 的邻接边中未染的最小颜色,\(q\) 为 \(y\) 的邻接边中未染的最小颜色。由于 \(\chi'(G)=\Delta(G)\),\(p,q\) 是存在的。
- 若 \(p=q\),令 \(f((x,y))=p\)。
- 若 \(p\not=q\),不妨令 \(p>q\),必然存在增广路 \(P=\lang x_1=x,y_1,x_2,y_2,\cdots,x_k\rang\),满足 \(\forall i\in[1,k),f((x_i,y_i))=p\land f((y_i,x_{i+1}))=q\)。同时,亦有 \(y\not\in P\)。我们翻转这条路径的边染色,即 \(f((x_i,y_i))\leftarrow q,f((y_i,x_{i+1}))\leftarrow p\)。此时可套用讨论 1.。
综上,每条边都能被染色且不出现共色的邻接边。命题得证。 \(\square\)
尝试将原命题向引理靠拢。令新图 \(G'\) 初始为 \(G\)。依次枚举 \(G'\) 中的结点 \(x\),尝试将其拆点。设 \(x\) 的邻接点集为 \(\operatorname{adj}(x)\),任取它的一个划分 \(S=\{S_1,\cdots,S_k\}\),满足 \(|S_1|=\cdots=|S_{k-1}|=c\),若 \(k>1\),则令 \(V_{G'}\leftarrow V_{G'}\cup\{x_1,\cdots,x_k\}\setminus\{x\}\),且 \(\operatorname{adj}(x_i)\leftarrow S_i\)。注意若 \(x\) 已是拆出的点,那么必然不会导致图的变动,拆点是可完成的。
此后,发现 \(\Delta(G')\le c\) 且 \(G'\) 依旧是二分图。由引理,\(\chi'(G)=\Delta(G)\),我们取出这样一个染色 \(f\),将拆点合并回原图 \(G\) 且不改变边染色,显然 \(f\) 取到了答案下界。 \(\square\)
\(\mathcal O(|X|+|Y|+|E|)\) 算一算就好。
\(\mathcal{Code}\)
/*~Rainybunny~*/
#ifndef RYBY
#pragma GCC optimize( "Ofast" )
#endif
#include <bits/stdc++.h>
#define rep( i, l, r ) for ( int i = l, rep##i = r; i <= rep##i; ++i )
#define per( i, r, l ) for ( int i = r, per##i = l; i >= per##i; --i )
inline char fgc() {
static char buf[1 << 17], *p = buf, *q = buf;
return p == q && ( q = buf + fread( p = buf, 1, 1 << 17, stdin ), p == q )
? EOF : *p++;
}
inline int rint() {
int x = 0, s = fgc();
for ( ; s < '0' || '9' < s; s = fgc() );
for ( ; '0' <= s && s <= '9'; s = fgc() ) x = x * 10 + ( s ^ '0' );
return x;
}
const int MAXN = 1e6;
int n, m, k, c, deg[MAXN + 5];
int main() {
freopen( "qiandao.in", "r", stdin );
freopen( "qiandao.out", "w", stdout );
n = rint(), m = rint(), k = rint(), c = rint();
rep ( i, 1, k ) {
int u = rint(), v = rint();
++deg[u], ++deg[v + n];
}
int ans = 0;
rep ( i, 1, n + m ) ans += !!( deg[i] % c );
printf( "%d\n", ans );
return 0;
}
Solution -「多校联训」签到题的更多相关文章
- Solution -「多校联训」Sample
\(\mathcal{Description}\) Link (稍作简化:)对于变量 \(p_{1..n}\),满足 \(p_i\in[0,1],~\sum p_i=1\) 时,求 \(\ma ...
- Solution -「多校联训」排水系统
\(\mathcal{Description}\) Link. 在 NOIP 2020 A 的基础上,每条边赋权值 \(a_i\),随机恰好一条边断掉,第 \(i\) 条段的概率正比于 \(a ...
- Solution -「多校联训」I Love Random
\(\mathcal{Description}\) 给定排列 \(\{p_n\}\),可以在其上进行若干次操作,每次选取 \([l,r]\),把其中所有元素变为原区间最小值,求能够得到的所有不同序 ...
- Solution -「多校联训」朝鲜时蔬
\(\mathcal{Description}\) Link. 破案了,朝鲜时蔬 = 超现实树!(指写得像那什么一样的题面. 对于整数集 \(X\),定义其 好子集 为满足 \(Y\sub ...
- Solution -「多校联训」假人
\(\mathcal{Description}\) Link. 一种物品有 长度 和 权值 两种属性,现给定 \(n\) 组物品,第 \(i\) 组有 \(k_i\) 个,分别为 \((1,a ...
- Solution -「多校联训」古老的序列问题
\(\mathcal{Description}\) Link. 给定序列 \(\{a_n\}\),和 \(q\) 次形如 \([L,R]\) 的询问,每次回答 \[\sum_{[l,r]\su ...
- Solution -「多校联训」自动机
\(\mathcal{Description}\) Link. 有一个状态集为 \(V\) 的自动机,状态接收 (, ) 和 _(空格) 三种字符,分别编号为 \(0,1,2\),状态 \(u ...
- Solution -「多校联训」战神归来
\(\mathcal{Description}\) Link. 一条地铁线路上共 \(m\) 个站点,\(n\) 个人乘坐地铁,第 \(i\) 个人需要从 \(s_i\) 站坐到 \(e_i\ ...
- Solution -「多校联训」消失的运算符
\(\mathcal{Description}\) Link. 给定长度为 \(n\) 的合法表达式序列 \(s\),其中数字仅有一位正数,运算符仅有 - 作为占位.求将其中恰好 \(k\) ...
随机推荐
- 基于CentOS7.x gitlab环境搭建,卸载,汉化 --搭建篇
gitlab环境搭建,卸载,汉化 --搭建篇 环境搭建 安装依赖软件 yum -y install policycoreutils openssh-server openssh-clients pos ...
- Maven+ajax+SSM实现新增
转载自:https://www.cnblogs.com/kebibuluan/p/9014986.html 20.尚硅谷_SSM高级整合_新增_创建员工新增的模态框.avi 1.接下来当我们点击增加按 ...
- 经典变长指令-ModRM
一.如何计算ModRM 0X88 MOV Eb,Gb G:通用寄存器 0X89 MOV Ev,Gv E:寄存器/内存 0X8A MOV Gb,Eb b:字节 0X8B MOV Gv,Ev v:Word ...
- 简述伪共享和缓存一致性MESI
什么是伪共享 计算机系统中为了解决主内存与CPU运行速度的差距,在CPU与主内存之间添加了一级或者多级高速缓冲存储器(Cache),这个Cache一般是集成到CPU内部的,所以也叫 CPU Cache ...
- python驱动SAP完成数据导出(二)
在上一篇 python驱动SAP完成数据导出(一)中,我们提到了数据导出前,SAP布局的重要性,如何识别当前布局模式,以及如何切换到想要的布局.本篇小爬将着重讲讲数据导出的注意事项. 我们可以通过如下 ...
- 开发 IDEA Plugin 引入探针,基于字节码插桩获取执行SQL
作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 片面了! 一月三舟,托尔斯泰说:"多么伟大的作家,也不过就是在书写自己的片 ...
- 论文翻译:2019_TCNN: Temporal convolutional neural network for real-time speech enhancement in the time domain
论文地址:TCNN:时域卷积神经网络用于实时语音增强 论文代码:https://github.com/LXP-Never/TCNN(非官方复现) 引用格式:Pandey A, Wang D L. TC ...
- Cesium应用篇--添加雨雪天气
作为一个三维地球,在场景中来点雨雪效果,貌似可以增加一点真实感.Cesium官网Demo中有天气系统的实例,用的是Cesium中的粒子系统做的.效果如下图所示,粒子系统的本质是向场景中添加了很多物体, ...
- echart的x轴或y轴区间标签如何从大到小排列
1.有时候我们做echart时,从后台接收返回回来的数据,没有按顺序排列,这里我遇到的是区间的值,看图 我这里是处理好了的,一开始,50-100这个区间在数组的最后一列,也就是在150-200后面的这 ...
- Servlet Filter(过滤器)
Servlet Filter 又称 Servlet 过滤器,它是在 Servlet 2.3 规范中定义的,能够对 Servlet 容器传给 Web 资源的 request 对象和 response 对 ...