【题解】CF1228D Complete Tripartite
题目大意:给定一个无向图,将它划分为三个点集,要求在一个点集中的点没有边相连,且颜色相同,不同集合中的点互相有边相连。
\(\text{Solution:}\)
我们发现,与一个点之间没有边相连的一定在同一个集合。
因为如果有边相连就已经违反了一个性质。
那么我们可以轻易确定一个集合。剩下的任务就是在剩下的点中确定另外两个集合。
我们遍历剩下没有确定的所有集合,随意找到一个点,将所有与它相连的、未染色的点划分为一个集合。
这样,剩下的点就是另一个集合。
证明:
对于除去已经确定的集合中的点,随意找到的点,它所相连的边,一种是属于已经确定的集合,就是已经染色的,直接跳过;
否则,其它边所连的点一定与它自己在不同集合中。而且,对于一个合法的划分,这是对所有点都满足的性质。
于是,我们随机找的正确性就有了保障。
并且还能证明出这样划分的集合形态唯一:对于一个点所连的所有点,因为我们选择先确定第一个集合,那么显然一个集合的点是确定的。因为与一个点没有边相连的点是确定的。
进一步地,因为我们已经证明随机选点的正确性,那我们随便选一个点,最终造成的结局一定是合法的(如果这个图有解)。因为对于任意个点都满足那个性质。
所以,我们随机选一个点并染色后,只需要一次判断就行了。
证毕。
首先判断每个集合中的点数是不是\(0\),无解情况之一。其次,枚举每个点对应的每条边,看看所连的点对应的集合是不是满足连满了对应的所有点。以及判断有没有与它相连的同一集合的点。
这题做完了。复杂度\(O(\text{min(n,m)})\)的亚子。
#include<bits/stdc++.h>
using namespace std;
const int MAXN=3e5+10;
int n,m,tot,head[MAXN<<1];
int col[MAXN],c[MAXN],cl[MAXN][4];
struct edge {
int nxt,to;
} e[MAXN<<1];
inline void add(int x,int y) {
e[++tot].to=y;
e[tot].nxt=head[x];
head[x]=tot;
}
int main() {
scanf("%d%d",&n,&m);
for(int i=1; i<=m; ++i) {
int x,y;
scanf("%d%d",&x,&y);
add(x,y);
add(y,x);
}
col[1]=1;
c[1]++;
for(int i=head[1]; i; i=e[i].nxt) {
int j=e[i].to;
col[j]=2;
}
for(int i=1; i<=n; ++i)if(!col[i])col[i]=1,c[1]++;
int s=2;
for(; s<=n&&col[s]!=2; s++);
for(int i=head[s]; i; i=e[i].nxt) {
int j=e[i].to;
if(col[j]==1)continue;
col[j]=3;
c[3]++;
}
c[2]=n-c[1]-c[3];
if(!c[1]||!c[2]||!c[3])return 0&puts("-1");
for(int x=1; x<=n; ++x) {
for(int i=head[x]; i; i=e[i].nxt) {
int j=e[i].to;
cl[x][col[j]]++;
}
for(int i=1; i<=3; ++i) {
if(col[x]!=i&&cl[x][i]!=c[i]) {
puts("-1");
return 0;
}
if(col[x]==i&&cl[x][i])return 0&puts("-1");
}
}
for(int i=1; i<=n; ++i)cout<<col[i]<<" ";
return 0;
}
【题解】CF1228D Complete Tripartite的更多相关文章
- CF1228D Complete Tripartite
思路: 任选一点a,和a没有边直接相连的点一定和a在同一个集合,由此构造得到一个集合A.用类似的方法再构造一个集合B,并将剩下的点放在集合C中,就得到了三个集合A,B,C.再检查A,B,C是否符合要求 ...
- Complete Tripartite
D - Complete Tripartite 思路:这个题是个染色问题.理解题意就差不多写出来一半了.开始的时候还想用离散化来储存每个点的状态,即它连接的点有哪些,但很无奈,点太多了,long lo ...
- 【Codeforces Round #589 (Div. 2) D】Complete Tripartite
[链接] 我是链接,点我呀:) [题意] 题意 [题解] 其实这道题感觉有点狗. 思路大概是这样 先让所有的点都在1集合中. 然后随便选一个点x,访问它的出度y 显然tag[y]=2 因为和他相连了嘛 ...
- PAT甲题题解-1064. Complete Binary Search Tree (30)-中序和层次遍历,水
由于是满二叉树,用数组既可以表示父节点是i,则左孩子是2*i,右孩子是2*i+1另外根据二分搜索树的性质,中序遍历恰好是从小到大排序因此先中序遍历填充节点对应的值,然后再层次遍历输出即可. 又是一道遍 ...
- PAT甲题题解-1110. Complete Binary Tree (25)-(判断是否为完全二叉树)
题意:判断一个节点为n的二叉树是否为完全二叉树.Yes输出完全二叉树的最后一个节点,No输出根节点. 建树,然后分别将该树与节点树为n的二叉树相比较,统计对应的节点个数,如果为n,则为完全二叉树,否则 ...
- CF #589 (Div. 2) D. Complete Tripartite 构造
这个 D 还是十分友好的~ 你发现这 $3$ 个集合形成了一个环的关系,所以随意调换顺序是无所谓的. 然后随便让 $1$ 个点成为第 $2$ 集合,那么不与这个点连边的一定也属于第二集合. 然后再随便 ...
- Codeforces Round #589 (Div. 2) D. Complete Tripartite(染色)
链接: https://codeforces.com/contest/1228/problem/D 题意: You have a simple undirected graph consisting ...
- Codeforces 1228D. Complete Tripartite
传送门 不妨设 $1$ 号点在集合 $1$ 里 那么对于其他点,有且只有所有和 $1$ 没有边的点都在集合 $1$ 里 考虑不在集合 $1$ 的任意一个点 $x$ ,不妨设它在集合 $2$ 里 那么所 ...
- cf1228 D Complete Tripartite(哈希)
题意: 无向简单图,无自环,无重边,n个点,m条边,请你将这n个点分为3个互相没有交集的集合.并且满足以下条件: 1.同一个集合中的任意两点之间没有边. 2.每个点都要与除了它这个集合以外的所有点相连 ...
随机推荐
- python执行gradle脚本
import os import shutil import subprocess #拷贝文件 def copyFile(srcFile, dstFile): #检查源文件是否存在 if not os ...
- centos7 RPM MySQL5.5
一.安装MYSQL 把下载好的rpm版的mysql上传到centos7中,目前公司中最爱用的是5.5版本和5.7版本,推荐用5.5. 先安装服务端 rpm -ivh MySQL-server-5.5. ...
- TinkPHP5.1开发注意事项
1.新下载的框架文件,开发前先开启调试配置 config目录下app.php文件 // 应用调试模式 'app_debug' => true, 2.每新建一个方法,都要 ...
- 小程序开发-开发模式下关闭http域名校验
小程序开发模式去掉域名校验 我们在开发小程序的时候如果用到其他网络地址,在小程序运行时调试器会输出 : http://www.example.com 不在以下 request 合法域名列表中,请参考文 ...
- 使用grep命令查找文件中符合”.stg.“行
某目录下有个test.txt,内容如下: www.stg.comwwstgcom 如果我这样去查找: $ grep '.stg.' test.txtwww.stg.comwwstgcom 发现第二个匹 ...
- python基础三(集合、文件)
1.集合定义 集合天生能去重,且与字典一样,无序.集合用大括号括起来,里面的元素之间用逗号分隔,要跟字典区分开. 集合定义方法:s=set() #定义一个空集合 s={'1','a','b','c', ...
- db2错误代码可能的原因
一. SQL5005C运行cmd未用管理员权限打开 SQLCODE-303 数据类型不兼容 SQLCODE-305 查出的数据有NULL未处理直接写入接收变量 二.应该不会有人直接写sql用这个 ...
- 乔悟空-CTF-i春秋-Misc-爆破3
hehe,第一次用这个,开始CTF刷题之旅 2020.09.02 题目地址 学习 题目分析 下边是题目给的php源码,意思就是进行源码审计,分析出能输出flag的条件. 这东西我是真小白,so,积累经 ...
- [程序员代码面试指南]递归和动态规划-排成一条线的纸牌博弈问题(DP)
题目 给定一个整型数组arr,代表数值不同的纸牌排成一条线.玩家A和玩家B依次拿走每张纸牌,规定玩家A先拿,玩家B后拿,但是每个玩家每次只能拿走最左或最右的纸牌,玩家A和玩家B都绝顶聪明.请返回最后获 ...
- Spring源码解析 | 第二篇:Spring IOC容器之XmlBeanFactory启动流程分析和源码解析
一. 前言 Spring容器主要分为两类BeanFactory和ApplicationContext,后者是基于前者的功能扩展,也就是一个基础容器和一个高级容器的区别.本篇就以BeanFactory基 ...