考试的时候想的是,将所有的完全子图缩起来,然后如果剩下的是一条链,依次对其进行标号即可。

看了官方题解,发现完全子图这个条件太强了,缩点的条件仅仅需要保证原本两个点的“邻接表”相同即可。(注意这里的“邻接表”需要把其自身也放进去)

自己构造一下,发现这个比较容易理解。

被缩在一起的点的标号相同。如果缩完是一条链,对其依次进行标号。否则无解。

复杂度发现比较鬼畜,但是想一下就会知道其不会太高。官方说可以证明是

#include<cstdio>
#include<vector>
#include<set>
#include<algorithm>
using namespace std;
int n,m,xs[300010],ys[300010];
struct data{
int id;
vector<int>ljb;
}nodes[300010];
bool cmp(const data &a,const data &b){
return a.ljb<b.ljb;
}
int bel[300010],nn,col[300010],du[300010];
set<pair<int,int> >S;
vector<int>G[300010];
int pen;
void dfs(int U){
col[U]=++pen;
for(int i=0;i<G[U].size();++i){
if(!col[G[U][i]]){
dfs(G[U][i]);
}
}
}
int main(){
// freopen("d.in","r",stdin);
scanf("%d%d",&n,&m);
for(int i=1;i<=m;++i){
scanf("%d%d",&xs[i],&ys[i]);
nodes[xs[i]].ljb.push_back(ys[i]);
nodes[ys[i]].ljb.push_back(xs[i]);
}
for(int i=1;i<=n;++i){
nodes[i].id=i;
nodes[i].ljb.push_back(i);
sort(nodes[i].ljb.begin(),nodes[i].ljb.end());
}
sort(nodes+1,nodes+n+1,cmp);
int sta;
for(int i=1;i<=n;++i){
if(nodes[i].ljb!=nodes[i-1].ljb){
sta=i;
}
if(nodes[i].ljb!=nodes[i+1].ljb){
++nn;
for(int j=sta;j<=i;++j){
bel[nodes[j].id]=nn;
}
}
}
for(int i=1;i<=m;++i){
if(bel[xs[i]]!=bel[ys[i]]){
if(S.find(make_pair(bel[xs[i]],bel[ys[i]]))==S.end() &&
S.find(make_pair(bel[ys[i]],bel[xs[i]]))==S.end()){
S.insert(make_pair(bel[xs[i]],bel[ys[i]]));
S.insert(make_pair(bel[ys[i]],bel[xs[i]]));
G[bel[xs[i]]].push_back(bel[ys[i]]);
G[bel[ys[i]]].push_back(bel[xs[i]]);
++du[bel[xs[i]]];
++du[bel[ys[i]]];
}
}
}
int cnt=0;
for(int i=1;i<=nn;++i){
if(du[i]==1){
++cnt;
}
else if(du[i]>2){
puts("NO");
return 0;
}
}
if(cnt==2 || (nn==1 && cnt==0)){
for(int i=1;i<=nn;++i){
if(du[i]==1 || du[i]==0){
dfs(i);
break;
}
}
puts("YES");
for(int i=1;i<n;++i){
printf("%d ",col[bel[i]]);
}
printf("%d\n",col[bel[n]]);
}
else{
puts("NO");
}
return 0;
}

【构造】Tinkoff Challenge - Final Round (Codeforces Round #414, rated, Div. 1 + Div. 2) D. Labelling Cities的更多相关文章

  1. Tinkoff Challenge - Final Round (Codeforces Round #414, rated, Div. 1 + Div. 2) 继续跪一把

    这次的前三题挺简单的,可是我做的不快也不对. A. Bank Robbery time limit per test 2 seconds memory limit per test 256 megab ...

  2. Tinkoff Challenge - Final Round (Codeforces Round #414, rated, Div. 1 + Div. 2)

    A: 思路:就是找b,c之前有多个s[i] 代码: #include<stdio.h>#define ll long longusing namespace std;ll a,b,c;in ...

  3. Tinkoff Challenge - Final Round (Codeforces Round #414, rated, Div. 1 + Div. 2) 【ABC】

    老年人题解,语言python3 A - Bank Robbery 题意:给你ABC,以及n个数,问你在(B,C)之间的数有多少个. 题解:对于每个数判断一下就好了嘛 x,y,z = map(int,i ...

  4. 【贪心】【multiset】Tinkoff Challenge - Final Round (Codeforces Round #414, rated, Div. 1 + Div. 2) C. Naming Company

    考虑两个人,先把各自的集合排个序,丢掉一半,因为比较劣的那一半一定用不到. 然后贪心地放,只有两种决策,要么把一个最优的放在开头,要么把一个最劣的放在结尾. 如果我的最优的比对方所有的都劣(或等于), ...

  5. Tinkoff Challenge - Final Round (ABC)

    A题:从两个保安中间那钞票 #include <bits/stdc++.h> using namespace std; int main() { int a,b,c; scanf(&quo ...

  6. CF Intel Code Challenge Final Round (Div. 1 + Div. 2, Combined)

    1. Intel Code Challenge Final Round (Div. 1 + Div. 2, Combined) B. Batch Sort    暴力枚举,水 1.题意:n*m的数组, ...

  7. 构造 Codeforces Round #302 (Div. 2) B Sea and Islands

    题目传送门 /* 题意:在n^n的海洋里是否有k块陆地 构造算法:按奇偶性来判断,k小于等于所有点数的一半,交叉输出L/S 输出完k个L后,之后全部输出S:) 5 10 的例子可以是这样的: LSLS ...

  8. Codeforces Round #275 (Div. 2) C - Diverse Permutation (构造)

    题目链接:Codeforces Round #275 (Div. 2) C - Diverse Permutation 题意:一串排列1~n.求一个序列当中相邻两项差的绝对值的个数(指绝对值不同的个数 ...

  9. Codeforces Round #275 (Div. 1)A. Diverse Permutation 构造

    Codeforces Round #275 (Div. 1)A. Diverse Permutation Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 ht ...

随机推荐

  1. 制作Solaris系统的USB启动盘

    制作方法: 1. wget http://192.168.2.5/surefiler-installer/2011-12-09/devel-2011.12.9.tgz 2. cd /root tar  ...

  2. Part2-HttpClient官方教程-Chapter5-流利的API

    5.1. 易于使用的Facade API 使用之前注意引入相应Jar包或者Maven依赖 <dependency> <groupId>org.apache.httpcompon ...

  3. [Leetcode Week15] Add Two Numbers

    Add Two Numbers 题解 原创文章,拒绝转载 题目来源:https://leetcode.com/problems/add-two-numbers/description/ Descrip ...

  4. device tree 負值 property 寫法

    倘若你要設定 負值的property, 可能需要括符才會 build 過. 正確 decidegc = <(-10)>; 錯誤 decidegc = <-10>;

  5. java===java基础学习(7)---用户自定义类

    package testbotoo; import java.util.*; public class EmployeeTest { public static void main(String[] ...

  6. C#通过反射获取类中的方法和参数个数,反射调用方法带参数

    using System; using System.Reflection; namespace ConsoleApp2 { class Program { static void Main(stri ...

  7. IE8下面的line-height的bug

    当line-height小于正常值时,超出的部分将被剪裁掉

  8. python插入oracle数据

    # coding=utf- ''''' Created on -- @author: ''' import json; import urllib2 import sys import cx_Orac ...

  9. NOIP 2013 day1

    tags: 模拟 快速幂 逆序对 树状数组 归并排序 最小生成树 lca 倍增 categories: 信息学竞赛 总结 tex live 2017.iso 转圈游戏 火柴排队 货车运输 转圈游戏 s ...

  10. python调用.so

    python调用动态链接库的基本过程 动态链接库在Windows中为.dll文件,在linux中为.so文件.以linux平台为例说明python调用.so文件的使用方法. 本例中默认读者已经掌握动态 ...