#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(抵达)(结论)相关推荐

  1. [LOJ#522]「LibreOJ β Round #3」绯色 IOI(危机)

    [LOJ#522]「LibreOJ β Round #3」绯色 IOI(危机) 试题描述 IOI 的比赛开始了.Jsp 和 Rlc 坐在一个角落,这时他们听到了一个异样的声音 -- 接着他们发现自己收 ...

  2. [匹配+拓扑] LibreOJ #521. 「LibreOJ β Round #3」绯色 IOI(抵达)

    题意 戳这里 题解 这题一开始感觉无从下手,所以我们要尝试得到一些结论. 自己画一画可以发现,一定是两两互为对方的庇护所.这样才有可能保证任意两个不同的城市庇护所不同.否则由于原图没有环,到后面必定会 ...

  3. loj 523 「LibreOJ β Round #3」绯色 IOI(悬念) 霍尔定理+基环树+线段树

    题目分析 神仙题(确信) 首先,j−aij-a _ ij−ai​和ai−ja _ i-jai​−j互为相反数,若其中最小值为bib _ ibi​,则一个为bib _ ibi​一个为m−bim-b _ ...

  4. #520. 「LibreOJ β Round #3」绯色 IOI(开端) 贪心

    妈耶,没脸见人了.巨水,想出来不写,人生重来算了. 就是个找规律题,相邻一个连一下,但是我没注意到是IOI赛制,以为是OI赛制所以没打,感觉70分好打但是懒得了.. 证明就是把相邻3个列一下式子就出来 ...

  5. 【LOJ520】「LibreOJ β Round #3」绯色 IOI(开端)

    传送门 题解: 排序. 现在问题是找出两条从111到nnn的路径使得代价最小. 显然路径上点的编号只可能递增. 容易证明iii和i+1i+1i+1不能存在于同一条路径中.考虑p<i<i+1 ...

  6. 「LibreOJ β Round #3」绯色 IOI(抵达)

    [题解] 我们可以发现叶子节点的关联点一定是它的父亲节点,那么我们dfs一遍就可以求出所有节点的关联点,或者判断出无解. 对于每个点i,它的关联点u的危险度肯定比它连接的其他点vi的危险度小,我们从u ...

  7. 【联合选讲】「LibreOJ β Round #3」绯色 IOI(悬念)

    题目 Description 胖头鱼从鱼戏团逃脱后,被主人一路追捕,他慌不择路地跑进了一颗n个节点的池子树,池子树的所有度数为1的点就是出口. 假如他现在在节点i,那么每个时刻他能选择向某个与当前点有 ...

  8. [结论] LibreOJ #520. 「LibreOJ β Round #3」绯色 IOI(开端)

    题意 戳这里 题解 这是一道结论题. 我们先把数放到数轴上考虑.定义两个点的距离为几何上的距离的平方. 我们可以把一个回路看作两条从 11 到 nn 的不相交的路径. 有一种经典的二路取数的 O(n2 ...

  9. loj #535. 「LibreOJ Round #6」花火 树状数组求逆序对+主席树二维数点+整体二分...

    $ \color{#0066ff}{ 题目描述 }$ 「Hanabi, hanabi--」 一听说祭典上没有烟火,Karen 一脸沮丧. 「有的哦-- 虽然比不上大型烟花就是了.」 还好 Shinob ...

最新文章

  1. 计算机科学与技术考,计算机科学与技术考研
  2. 生成随机数放入整型数组怎么判断有没有重复_图的应用(1)-连通图的最小生成树(Prim算法和Kruskal算法)...
  3. PMP-【第15章 PMP考试的难点与易点】2021-2-17(304页-312页)【完】
  4. Java之Number类
  5. SAP Spartacus的自定义路由
  6. 一步一步写算法(之洗牌算法)
  7. SQLServer XML操作
  8. Linux 编译 libc log,在Android的源码中添加LOG
  9. STM32之点亮LED
  10. JS取得RadioButtonList的Value,Text及选中值等信息
  11. 内码输入法手机版下载_win7 64位内码输入法下载
  12. 智能网联汽车 自动驾驶功能场地试验方法及要求
  13. Matlab之min()、max()函数(求最小、最大值)
  14. 概率统计笔记之 “数学期望和方差”
  15. HDFS dfsclient读文件过程 源码分析
  16. 线性空间 android 变黑,Unity手游开发札记——Unity线性空间下移动设备上烘焙变暗问题处理笔记...
  17. 微信公众号开发--公众号关注推送配置与菜单配置
  18. MySQL高可用之DRBD
  19. 有一副由NxN矩阵表示的图像,这里每个像素用一个int表示,请编写一个算法,在不占用额外内存空间的情况下(即不使用缓存矩阵),将图像顺时针旋转90度。 给定一个NxN的矩阵,和矩阵的阶数N,请返回旋转
  20. 计算机主机拆卸心得,1计算机硬件拆装实验报告(01)

热门文章

  1. 《SAS编程与数据挖掘商业案例》学习笔记之十四
  2. 下班忘打卡了什么后果_工厂园区安装人脸识别门禁系统有什么好处?
  3. oracle中sum和count可以嵌套吗_【分享吧】Oracle查询转换
  4. python浪漫代码_五行Python代码实现批量抠图
  5. TDengine和DolphinDB哪个更好,哈哈哈哈,闲来无聊分析了一下。
  6. 计算机的科学原理是什么,人工智能的工作原理是什么?
  7. java虚拟机工作原理图_Java虚拟机工作原理
  8. 开发物体识别桌、_【课程总结】AR系统开发“秘籍”大揭秘!
  9. lnmp无法远程连接mysql_MySQL(一):设置root 可以远程连接MySQL
  10. spring的钩子_spring提供的钩子,你知道哪些