【构造】Tinkoff Challenge - Final Round (Codeforces Round #414, rated, Div. 1 + Div. 2) D. Labelling Cities
考试的时候想的是,将所有的完全子图缩起来,然后如果剩下的是一条链,依次对其进行标号即可。
看了官方题解,发现完全子图这个条件太强了,缩点的条件仅仅需要保证原本两个点的“邻接表”相同即可。(注意这里的“邻接表”需要把其自身也放进去)
自己构造一下,发现这个比较容易理解。
被缩在一起的点的标号相同。如果缩完是一条链,对其依次进行标号。否则无解。
复杂度发现比较鬼畜,但是想一下就会知道其不会太高。官方说可以证明是
。
#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的更多相关文章
- 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 ...
- 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 ...
- 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 ...
- 【贪心】【multiset】Tinkoff Challenge - Final Round (Codeforces Round #414, rated, Div. 1 + Div. 2) C. Naming Company
考虑两个人,先把各自的集合排个序,丢掉一半,因为比较劣的那一半一定用不到. 然后贪心地放,只有两种决策,要么把一个最优的放在开头,要么把一个最劣的放在结尾. 如果我的最优的比对方所有的都劣(或等于), ...
- Tinkoff Challenge - Final Round (ABC)
A题:从两个保安中间那钞票 #include <bits/stdc++.h> using namespace std; int main() { int a,b,c; scanf(&quo ...
- 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的数组, ...
- 构造 Codeforces Round #302 (Div. 2) B Sea and Islands
题目传送门 /* 题意:在n^n的海洋里是否有k块陆地 构造算法:按奇偶性来判断,k小于等于所有点数的一半,交叉输出L/S 输出完k个L后,之后全部输出S:) 5 10 的例子可以是这样的: LSLS ...
- Codeforces Round #275 (Div. 2) C - Diverse Permutation (构造)
题目链接:Codeforces Round #275 (Div. 2) C - Diverse Permutation 题意:一串排列1~n.求一个序列当中相邻两项差的绝对值的个数(指绝对值不同的个数 ...
- 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 ...
随机推荐
- JQuery-Ajax后台提交数据与获取数据 Java代码
function jqajax(){ var urlName = $("#urlName").val(); var urla = $("#url").val() ...
- 【1】记一次破解wifi
当然,使用的依旧是aircrack套件,这次依旧是跑字典,今天,捉到了另一个实验室icephone的wpa握手包,我猜测实验室的wifi一般都跟自己的名字有关,icephone刚好是8位字母,于是我就 ...
- 2018DDCTF Misc部分WP
题目给出了这样一串字符:d4e8e1f4a0f7e1f3a0e6e1f3f4a1a0d4e8e5a0e6ece1e7a0e9f3baa0c4c4c3d4c6fbb9e1e6b3e3b9e4b3b7b7 ...
- ADC 計算時,階數的選擇
reference : ADC 階數的計算
- 超级rtmp服务器和屌丝wowza
超级rtmp服务器和屌丝wowza http://blog.csdn.net/win_lin/article/details/11927973
- KettleDB连接jdbc连接池参数介绍
http://sheng8407-sina-com.iteye.com/blog/1163245 http://blog.csdn.net/dingxingmei/article/details/41 ...
- MYSQL5.5源码安装 linux下
/* 首先安装必要的库 */ yum -y install gcc* ###### 安装 MYSQL ###### 首先安装camke 一.支持YUM,则 yum install -y cmake 二 ...
- Oralce Spatial
1.建立数据库连接 create public database link ytlink connect to hightop identified by hightop using '(DESCRI ...
- Mac 使用自带的Ruby 安装brew
Homebrew简称brew,OSX上的软件包管理工具,在Mac终端可以通过brew安装.更新.卸载软件. 首先要安装brew,在 mac 中使用finder 搜索 终端(terminal)打开命令行 ...
- python中烦人的锟斤拷(\xef\xbf\xbd)
首先要知道\xef\xbf\xbd是啥东西 >>> u'\uFFFD'.encode('utf-8') '\xef\xbf\xbd' 由此我们可以知道\xef\xbf\xbd是utf ...