\(\mathcal{Description}\)

  Link.

  求含有 \(n\) 个结点的所有有标号简单无向图中,最小点覆盖为 \(m\) 的图的数量的奇偶性。\(T\) 组数据。

  \(n,m\le3\times10^3\),\(T\le5\times10^3\)。

\(\mathcal{Solution}\)

  太神了叭!

  总不能硬刚 NPC,我们必须牢牢把握“奇偶性”带来的便利:若存在某种规则将一类图两两配对,则我们可以忽略这些图而不影响答案。顺便做一步转化,最小点覆盖 = \(n\) - 最大独立集 = 补图的最大团,我们直接限制最大团的大小也能达到目标而更便于后续计算。

  以下均在补图上考虑问题。从配对入手,令 \(S_u\) 为点 \(u\) (在某个具体的补图上)的邻接点集,任取两点,不妨取结点 \(1\) 和结点 \(2\),讨论:

  • \(S_1\setminus\{2\}\not=S_2\setminus\{1\}\):交换结点 \(1,2\) 的标号得到新图,它与原图不同且最大团必然相等,构成配对,不考虑。

  • \(S_1\setminus\{2\}=S_2\setminus\{1\}\)

    在此,引入“缩点”操作,每个结点代表着邻接点集相同的结点构成的团。

    • \((1,2)\in E\):这意味这两团等大且互相连边构成大团,\(1\) 和 \(2\) 可以看做一个大小增大一倍的团;
    • \((1,2)\not\in E\):类似地,两团最多有一个是全局最大团的子集,所以 \(1\) 和 \(2\) 可以看做一个大小不变的团。

那么,任何一个时刻的图上不会存在等大的团,且每个团的大小为 \(2\) 的整幂,这样的图只有 \(\mathcal O(n)\) 个,利用一个 \(i\in[1,n]\) 的二进制表示就能描述整个图。自然地,令 \(f(n,i)\) 表示(全局)一共有 \(n\) 个结点,图的状态为 \(i\) 时方案的奇偶性。考虑增加一个新点并与若干团合并,类似于考虑 \(i+1\) 在二进制下的进位,可以轻松得到转移。

  不过,我们最终的问题与图的状态无直接关联,我们需要对于一个状态 \(t\),再求出由它得到最大团为 \(m\) 的方案的奇偶性。不妨令状态 \(t\) 中团的大小由大到小依次为 \(s_1,s_2,\cdots,s_k\),研究最大团的构成:

  • 存在 \(1<i<j\le k\),\(s_i,s_j\) 均不包含于最大团中。由“团的大小是 \(2\) 的整幂”,可见 \(s_i+s_j\) 必然小于最大团大小,那么 \(s_i\) 与 \(s_j\) 之间的边有连或不连两种方案,\(\times 2\)!这样的方案全部忽略掉!
  • 有且仅有 \(1<i<k\),\(s_i\) 不包含于最大团中。不论 \(i\) 与 \(j\in[1,i)\) 的团连边情况如何,\(i\) 与 \(j\in(i,k]\) 的连边情况不可能推翻钦定的最大团大小,所以会有 \(\times2^{k-i}\),这样的方案也毫无作用!
  • 最后,仅剩下两种可能——所有 \(s\) 一起构成最大团;仅有最小的 \(s\) 不属于最大团。设总点数 \(n'\),它们分别对大小 \(n'\) 和 \(n'-\operatorname{lowbit}(n')\) 的最大团产生 \(1\) 的贡献。

  最后,枚举 \(f(n,i)\) 中的图状态 \(i\),乘上对应状态下最大团大小恰好为 \(n-m\)(第一步转化带来的改动)的方案,可以做到 \(\mathcal O(n^2+Tn)\) 解决本题。考虑到满足最大团大小条件的方案很少,可以进一步优化,做到 \(\mathcal O(n^2+T)\)。只不过兔子咕啦。

\(\mathcal{Code}\)

/*~Rainybunny~*/

#include <cstdio>

#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 ) const int MAXN = 3000;
bool f[MAXN + 5][MAXN + 5], g[MAXN + 5][MAXN + 5]; inline void init() {
f[1][1] = 1;
rep ( i, 1, MAXN - 1 ) rep ( j, 1, i ) {
int rs = j, nw = 1;
if ( !f[i][j] ) continue;
for ( ; rs & nw; rs ^= nw, nw <<= 1 ) f[i + 1][rs] ^= 1;
f[i + 1][rs | nw] ^= 1;
} rep ( i, 1, MAXN ) {
g[i][i] = 1;
if ( i & ( i - 1 ) ) g[i][i ^ ( i & -i )] = 1;
}
} inline bool solve( const int n, const int m ) {
bool ret = 0;
rep ( i, 1, n ) ret ^= f[n][i] & g[i][m];
return ret;
} int main() {
freopen( "cover.in", "r", stdin );
freopen( "cover.out", "w", stdout ); init();
int T, n, m; scanf( "%d", &T );
while ( T-- ) {
scanf( "%d %d", &n, &m );
puts( m < n && solve( n, n - m ) ? "1" : "0" );
}
return 0;
}

Solution -「多校联训」最小点覆盖的更多相关文章

  1. Solution -「多校联训」I Love Random

    \(\mathcal{Description}\)   给定排列 \(\{p_n\}\),可以在其上进行若干次操作,每次选取 \([l,r]\),把其中所有元素变为原区间最小值,求能够得到的所有不同序 ...

  2. Solution -「多校联训」签到题

    \(\mathcal{Description}\)   Link.   给定二分图 \(G=(X\cup Y,E)\),求对于边的一个染色 \(f:E\rightarrow\{1,2,\dots,c\ ...

  3. Solution -「多校联训」古老的序列问题

    \(\mathcal{Description}\)   Link.   给定序列 \(\{a_n\}\),和 \(q\) 次形如 \([L,R]\) 的询问,每次回答 \[\sum_{[l,r]\su ...

  4. Solution -「多校联训」数学考试

    \(\mathcal{Description}\)   Link.   给定 \(n\) 个函数,第 \(i\) 个有 \(f_i(x)=a_ix^3+b_ix^2+cx_i+d~(x\in[l_i, ...

  5. Solution -「多校联训」最大面积

    \(\mathcal{Description}\)   Link.   平面上有 \(n\) 个点 \(A_{1..n}\),\(q\) 次询问,每次给出点 \(P\),求 \[\max_{1\le ...

  6. Solution -「多校联训」战神归来

    \(\mathcal{Description}\)   Link.   一条地铁线路上共 \(m\) 个站点,\(n\) 个人乘坐地铁,第 \(i\) 个人需要从 \(s_i\) 站坐到 \(e_i\ ...

  7. Solution -「多校联训」排水系统

    \(\mathcal{Description}\)   Link.   在 NOIP 2020 A 的基础上,每条边赋权值 \(a_i\),随机恰好一条边断掉,第 \(i\) 条段的概率正比于 \(a ...

  8. Solution -「多校联训」朝鲜时蔬

    \(\mathcal{Description}\)   Link.   破案了,朝鲜时蔬 = 超现实树!(指写得像那什么一样的题面.   对于整数集 \(X\),定义其 好子集 为满足 \(Y\sub ...

  9. Solution -「多校联训」消失的运算符

    \(\mathcal{Description}\)   Link.   给定长度为 \(n\) 的合法表达式序列 \(s\),其中数字仅有一位正数,运算符仅有 - 作为占位.求将其中恰好 \(k\) ...

随机推荐

  1. c# - 数据类型转换和控制台输入

    1.使用c#自带的 Convert类转换数据类型 2.源码 using System; namespace ConsoleApp1.toValue { class excutejiecheng { s ...

  2. Cache一致性协议与伪共享问题

    Cache一致性协议 在说伪共享问题之前,有必要聊一聊什么是Cache一致性协议 局部性原理 时间局部性:如果一个信息项正在被访问,那么在近期它很可能还会被再次访问 比如循环.方法的反复调用等 空间局 ...

  3. ADO.NET数据访问基础与综合应用2020年10月31日20:17:09学习笔记

    四.创建数据表 1.数据表的名称. 2.表中的字段名.数据类型.是否可以为空.字段的约束.必备的字段(通常会有一个ID,表示实体的唯一性:可以直接手写,也可以使用种子标识自动生成,给定起始值,给定增长 ...

  4. 我的2021年度总结-回忆录|附旅行Vlog

    今天是农历腊月初十,还有20天就是2022年了.这一年,些许遗憾,些许期盼.时间久了,很多事已经慢慢模糊了,只记得,这最后几个月的闲碎小事. 不止多久,很久没有码字了.有些事,记不清,忆不得.时至今年 ...

  5. Solon 开发,七、自定义注解开发汇总

    Solon 开发 一.注入或手动获取配置 二.注入或手动获取Bean 三.构建一个Bean的三种方式 四.Bean 扫描的三种方式 五.切面与环绕拦截 六.提取Bean的函数进行定制开发 七.自定义注 ...

  6. Cesium官方英文论坛

    Cesium中文网:http://cesiumcn.org/ | 国内快速访问:http://cesium.coinidea.com/ Cesium官方刚刚完成了将Google Groups论坛转移到 ...

  7. 猪齿鱼 Choerodon 的数据初始化设计解析

    数智化效能平台猪齿鱼Choerodon 作为一个微服务框架,需要解决微服务数据初始化本身具有的问题和复杂性,同时也需要满足框架本身特有的数据初始化需求,下面为大家介绍一下这方面的设计思想和实现. 微服 ...

  8. linux 创建用户 用户组,sudo,禁止root远程ssh登录

    创建用户  useradd hanli 为新用户设置密码(在root下可以为普通用户重置密码)  passwd hanli 创建用户组  groupadd  op 将用户添加到用户组  usermod ...

  9. dubbo-gateway 高性能dubbo网关

    dubbo-gateway dubbo-gateway 提供了http协议到dubbo协议的转换,但[并非]使用dubbo的[泛化]调用(泛化调用性能比普通调用有10-20%的损耗,通过普通异步的调用 ...

  10. WEB前端基础之SCC(字体颜色背景-盒子模型)

    目录 一:伪元素选择器 1.首字调整>>>:也是一种文档布局的方式 2.在文本的前面通过css动态渲染文本>>>:特殊文本无法选中 3.在文本的后面通过css动态渲 ...