2013亚洲区域赛长沙站 ZOJ 3732 Graph Reconstruction
题目链接
题意
给你无向图每个点的度数, 问是否存在唯一解, 存在输出唯一解, 多解输出两个, 无解输出IMPOSSIBLE
思路
这里用到了 Havel-Hakimi定理, 实际上就是按照度数构图的一种贪心策略. 这样能判断出来一个解或无解, 多解的情况, 只要在比较构图时最后面两个点的当前度数一样, 那么选其一都是可行的, 但是选其一的情况有保证了另外一个肯定没有连上, 所以能找到其它解.
代码
#include <bits/stdc++.h>
#define LL long long
#define INF 0x3f3f3f3f
#define eps 1e-8
using namespace std;
struct Node{
int val, pos;
}d[105], b[105];
pair<int, int> res1[10005], res2[10005];
int cnt1, cnt2;
bool compare(Node x, Node y){
return x.val > y.val;
}
int main(){
#ifndef ONLINE_JUDGE
freopen("in.txt", "r", stdin);
//freopen("out.txt", "w", stdout);
#endif // ONLINE_JUDGE
int n;
while (~scanf("%d", &n)){
bool noans = false;
cnt1 = cnt2 = 0;
for (int i = 1; i <= n; i++){
scanf("%d", &d[i].val);
d[i].pos = i;
if (d[i].val > n - 1) noans = true;
b[i] = d[i];
}
sort(d + 1, d + n + 1, compare);
bool isunique = true;
while (!noans){
if (d[1].val == 0) break;
for (int i = 2; i < 2 + d[1].val; i++){
d[i].val--;
res1[cnt1++] = make_pair(d[1].pos, d[i].pos);
if (d[i].val < 0){
noans = true;
break;
}
}
if (d[2 + d[1].val].val - d[1 + d[1].val].val == 1){
isunique = false;
}
d[1].val = 0;
sort(d + 1, d + n + 1, compare);
}
if (noans){
printf("IMPOSSIBLE\n");
continue;
}
if (isunique){
printf("UNIQUE\n");
}
else{
printf("MULTIPLE\n");
for (int i = 1; i <= n; i++){
d[i] = b[i];
}
sort(d + 1, d + n + 1, compare);
bool first = true;
while (d[1].val != 0){
for (int i = 2; i < 1 + d[1].val; i++){
d[i].val--;
res2[cnt2++] = make_pair(d[1].pos, d[i].pos);
}
if (first && d[1 + d[1].val].val == d[2 + d[1].val].val){
first = false;
d[2 + d[1].val].val--;
res2[cnt2++] = make_pair(d[1].pos, d[2 + d[1].val].pos);
}
else{
d[1 + d[1].val].val--;
res2[cnt2++] = make_pair(d[1].pos, d[1 + d[1].val].pos);
}
d[1].val = 0;
sort(d + 1, d + n + 1, compare);
}
}
printf("%d %d\n", n, cnt1);
for (int i = 0; i < cnt1; i++){
printf("%d ", res1[i].first);
}
printf("\n");
for (int i = 0; i < cnt1; i++){
printf("%d ", res1[i].second);
}
printf("\n");
if (!isunique){
printf("%d %d\n", n, cnt2);
for (int i = 0; i < cnt2; i++){
printf("%d ", res2[i].first);
}
printf("\n");
for (int i = 0; i < cnt2; i++){
printf("%d ", res2[i].second);
}
printf("\n");
}
}
}
2013亚洲区域赛长沙站 ZOJ 3732 Graph Reconstruction的更多相关文章
- 2013 ACM区域赛长沙 H zoj 3733 (hdu 4798) Skycity
题意:一个圆台,底面和顶面半径分别为R,r,然后高度为H,一共F层,每层高度一样,然后要在每层的天花板上贴方格玻璃,方格玻璃要满足以下几个条件: 方格玻璃面积不能小于S,且方格玻璃要围成一个正多边形, ...
- 2019~2020icpc亚洲区域赛徐州站H. Yuuki and a problem
2019~2020icpc亚洲区域赛徐州站H. Yuuki and a problem 题意: 给定一个长度为\(n\)的序列,有两种操作: 1:单点修改. 2:查询区间\([L,R]\)范围内所有子 ...
- 2014ACM/ICPC亚洲区域赛牡丹江站汇总
球队内线我也总水平,这所学校得到了前所未有的8地方,因为只有两个少年队.因此,我们13并且可以被分配到的地方,因为13和非常大的数目.据领队谁oj在之上a谁去让更多的冠军.我和tyh,sxk,doub ...
- ACM-ICPC 2016亚洲区域赛(沈阳站)游记(滚粗记)
首发于QQ空间和知乎,我在这里也更一下. 前言 以前高中搞竞赛的时候,经常看到神犇出去比赛或者训练之后写游记什么的,感觉萌萌哒.但是由于太弱,就没什么心情好写.现在虽然还是很弱,但是抱着享受的心情 ...
- 第42届亚洲区域赛青岛站(2017icpc青岛)经验总结以及一些感想
上一次写这种东西还是天梯赛,当时打完心里也是挺激动的,然后我们队也没有去参加省赛,但是过了一段时间我还是从那里面恢复了出来.因为我当时确实还是很菜的,当时连个暴力都不会,看着自己仅过的那些百度的题目确 ...
- 2014ACM/ICPC亚洲区域赛牡丹江站现场赛-A ( ZOJ 3819 ) Average Score
Average Score Time Limit: 2 Seconds Memory Limit: 65536 KB Bob is a freshman in Marjar Universi ...
- 2013 ACM-ICPC亚洲区域赛南京站C题 题解 轮廓线DP
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4804 题目大意 给你一个 \(n \times m\) 的矩形区域.你需要用 \(1 \times 1 ...
- 2014ACM/ICPC亚洲区域赛牡丹江站现场赛-K ( ZOJ 3829 ) Known Notation
Known Notation Time Limit: 2 Seconds Memory Limit: 65536 KB Do you know reverse Polish notation ...
- 【2013 ICPC亚洲区域赛成都站 F】Fibonacci Tree(最小生成树+思维)
Problem Description Coach Pang is interested in Fibonacci numbers while Uncle Yang wants him to do s ...
随机推荐
- XML 解析---dom解析和sax解析
眼下XML解析的方法主要用两种: 1.dom解析:(Document Object Model.即文档对象模型)是W3C组织推荐的解析XML的一种方式. 使用dom解析XML文档,该解析器会先把XML ...
- 为什么整个互联网行业都缺前端project师?
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/ ...
- Android基础新手教程——1.5.2 Git之使用GitHub搭建远程仓库
Android基础新手教程--1.5.2 Git之使用GitHub搭建远程仓库 标签(空格分隔): Android基础新手教程 本节引言: 在上一节中.我们学习了怎样使用Git.构建我们的本地仓库.轻 ...
- [codeforces 852 D] Exploration Plan 解题报告 (二分+最大匹配)
题目链接:http://codeforces.com/problemset/problem/852/D 题目大意: 有V个点,N个队伍,E条边,经过每条边有个时间,告诉你初始N个队伍的位置,求至少有K ...
- SAS小记
2011年8月13日 最近一直在跟着李东风的<统计软件教程>学习SAS,刚刚学完初等统计,感觉还没入门,找不到matlab编程时那种手顺的感觉.继续学习吧,加油! 最近用spss处 ...
- word2tex之类的问题
首先就是这个word2tex一般是在word和tex文本互相转换的时候用的. 以前win7下用的chikrii忘了使用方法.. 之后再win10下用的excel2tex,但是转换时候总感觉不如word ...
- AOJ GRL_1_B: Shortest Path - Single Source Shortest Path (Negative Edges) (Bellman-Frod算法求负圈和单源最短路径)
题目链接: http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=GRL_1_B Single Source Shortest Path ...
- 转js resplace方法使用
作者: hezhiwu5#163.com 时间:2007-3-22 大家好!!今晚在华软G43*宿舍没什么事做,把javascript中replace方法讲解一下,如果讲得不对或不合理是情理之中 ...
- Codeforces Round #289 Div 2
A. Maximum in Table 题意:给定一个表格,它的第一行全为1,第一列全为1,另外的数满足a[i][j]=a[i-1][j]+a[i][j-1],求这个表格中的最大的数 a[n][n]即 ...
- 51nod 1110 距离之和最小V3
X轴上有N个点,每个点除了包括一个位置数据X[i],还包括一个权值W[i].点P到点P[i]的带权距离 = 实际距离 * P[i]的权值.求X轴上一点使它到这N个点的带权距离之和最小,输出这个最小的带 ...