[LOJ #521]「LibreOJ β Round #3」绯色 IOI(抵达)(结论)
#521. 「LibreOJ β Round #3」绯色 IOI(抵达)
description
solution
因为点的庇护所不能为自身,题目背景在树上,有结论一定是两个相邻点互为庇护所
所以树一定要能两两完美匹配才有解
判断完有解后就是构造解了,用类似拓扑的算法
对于互为庇护所的i,ji,ji,j点,iii向jjj其它儿子连边,jjj同理
庇护所的权值得最小,所以要先入队先从队列里面出来
对于同时在队列里面的点按照编号排序,则是满足了字典序最小的要求
至此,本题被完美解决
code
#include <cstdio>
#include <vector>
#include <queue>
using namespace std;
#define maxn 500005
priority_queue < int, vector < int >, greater < int > > q;
vector < int > G[maxn], R[maxn];
int n;
int f[maxn], d[maxn], ans[maxn];
bool vis[maxn];void dfs( int u, int fa ) {f[u] = fa;for( int i = 0;i < G[u].size();i ++ ) {int v = G[u][i];if( v == fa ) continue;else dfs( v, u );}if( u != 1 && ! vis[u] && ! vis[fa] ) {vis[u] = vis[fa] = 1;for( int i = 0;i < G[fa].size();i ++ )if( G[fa][i] == u ) continue;else R[u].push_back( G[fa][i] ), d[G[fa][i]] ++;for( int i = 0;i < G[u].size();i ++ )if( G[u][i] == fa ) continue;else R[fa].push_back( G[u][i] ), d[G[u][i]] ++;}
}int main() {scanf( "%d", &n );for( int i = 1, u, v;i < n;i ++ ) {scanf( "%d %d", &u, &v );G[u].push_back( v );G[v].push_back( u );}dfs( 1, 0 );for( int i = 1;i <= n;i ++ )if( ! vis[i] ) return ! printf( "-1\n" );for( int i = 1;i <= n;i ++ )if( ! d[i] ) q.push( i );int cnt = 0;while( ! q.empty() ) {int u = q.top(); q.pop();ans[++ cnt] = u;for( int i = 0;i < R[u].size();i ++ ) {int v = R[u][i];d[v] --;if( ! d[v] ) q.push( v );}}for( int i = 1;i <= n;i ++ )printf( "%d ", ans[i] );return 0;
}
[LOJ #521]「LibreOJ β Round #3」绯色 IOI(抵达)(结论)相关推荐
- [LOJ#522]「LibreOJ β Round #3」绯色 IOI(危机)
[LOJ#522]「LibreOJ β Round #3」绯色 IOI(危机) 试题描述 IOI 的比赛开始了.Jsp 和 Rlc 坐在一个角落,这时他们听到了一个异样的声音 -- 接着他们发现自己收 ...
- [匹配+拓扑] LibreOJ #521. 「LibreOJ β Round #3」绯色 IOI(抵达)
题意 戳这里 题解 这题一开始感觉无从下手,所以我们要尝试得到一些结论. 自己画一画可以发现,一定是两两互为对方的庇护所.这样才有可能保证任意两个不同的城市庇护所不同.否则由于原图没有环,到后面必定会 ...
- loj 523 「LibreOJ β Round #3」绯色 IOI(悬念) 霍尔定理+基环树+线段树
题目分析 神仙题(确信) 首先,j−aij-a _ ij−ai和ai−ja _ i-jai−j互为相反数,若其中最小值为bib _ ibi,则一个为bib _ ibi一个为m−bim-b _ ...
- #520. 「LibreOJ β Round #3」绯色 IOI(开端) 贪心
妈耶,没脸见人了.巨水,想出来不写,人生重来算了. 就是个找规律题,相邻一个连一下,但是我没注意到是IOI赛制,以为是OI赛制所以没打,感觉70分好打但是懒得了.. 证明就是把相邻3个列一下式子就出来 ...
- 【LOJ520】「LibreOJ β Round #3」绯色 IOI(开端)
传送门 题解: 排序. 现在问题是找出两条从111到nnn的路径使得代价最小. 显然路径上点的编号只可能递增. 容易证明iii和i+1i+1i+1不能存在于同一条路径中.考虑p<i<i+1 ...
- 「LibreOJ β Round #3」绯色 IOI(抵达)
[题解] 我们可以发现叶子节点的关联点一定是它的父亲节点,那么我们dfs一遍就可以求出所有节点的关联点,或者判断出无解. 对于每个点i,它的关联点u的危险度肯定比它连接的其他点vi的危险度小,我们从u ...
- 【联合选讲】「LibreOJ β Round #3」绯色 IOI(悬念)
题目 Description 胖头鱼从鱼戏团逃脱后,被主人一路追捕,他慌不择路地跑进了一颗n个节点的池子树,池子树的所有度数为1的点就是出口. 假如他现在在节点i,那么每个时刻他能选择向某个与当前点有 ...
- [结论] LibreOJ #520. 「LibreOJ β Round #3」绯色 IOI(开端)
题意 戳这里 题解 这是一道结论题. 我们先把数放到数轴上考虑.定义两个点的距离为几何上的距离的平方. 我们可以把一个回路看作两条从 11 到 nn 的不相交的路径. 有一种经典的二路取数的 O(n2 ...
- loj #535. 「LibreOJ Round #6」花火 树状数组求逆序对+主席树二维数点+整体二分...
$ \color{#0066ff}{ 题目描述 }$ 「Hanabi, hanabi--」 一听说祭典上没有烟火,Karen 一脸沮丧. 「有的哦-- 虽然比不上大型烟花就是了.」 还好 Shinob ...
最新文章
- 计算机科学与技术考,计算机科学与技术考研
- 生成随机数放入整型数组怎么判断有没有重复_图的应用(1)-连通图的最小生成树(Prim算法和Kruskal算法)...
- PMP-【第15章 PMP考试的难点与易点】2021-2-17(304页-312页)【完】
- Java之Number类
- SAP Spartacus的自定义路由
- 一步一步写算法(之洗牌算法)
- SQLServer XML操作
- Linux 编译 libc log,在Android的源码中添加LOG
- STM32之点亮LED
- JS取得RadioButtonList的Value,Text及选中值等信息
- 内码输入法手机版下载_win7 64位内码输入法下载
- 智能网联汽车 自动驾驶功能场地试验方法及要求
- Matlab之min()、max()函数(求最小、最大值)
- 概率统计笔记之 “数学期望和方差”
- HDFS dfsclient读文件过程 源码分析
- 线性空间 android 变黑,Unity手游开发札记——Unity线性空间下移动设备上烘焙变暗问题处理笔记...
- 微信公众号开发--公众号关注推送配置与菜单配置
- MySQL高可用之DRBD
- 有一副由NxN矩阵表示的图像,这里每个像素用一个int表示,请编写一个算法,在不占用额外内存空间的情况下(即不使用缓存矩阵),将图像顺时针旋转90度。 给定一个NxN的矩阵,和矩阵的阶数N,请返回旋转
- 计算机主机拆卸心得,1计算机硬件拆装实验报告(01)
热门文章
- 《SAS编程与数据挖掘商业案例》学习笔记之十四
- 下班忘打卡了什么后果_工厂园区安装人脸识别门禁系统有什么好处?
- oracle中sum和count可以嵌套吗_【分享吧】Oracle查询转换
- python浪漫代码_五行Python代码实现批量抠图
- TDengine和DolphinDB哪个更好,哈哈哈哈,闲来无聊分析了一下。
- 计算机的科学原理是什么,人工智能的工作原理是什么?
- java虚拟机工作原理图_Java虚拟机工作原理
- 开发物体识别桌、_【课程总结】AR系统开发“秘籍”大揭秘!
- lnmp无法远程连接mysql_MySQL(一):设置root 可以远程连接MySQL
- spring的钩子_spring提供的钩子,你知道哪些