NOIP2019 旅行
注意!注意!前方高能!本题卡常!!!
我们发现,所有的狗血剧情都在告诉我们,树的话直接dfs就出来了
那么基环树呢?
其实只要暴力删边,理论上的复杂度是可以过的qwq
但是删哪条边呢?
这里要引出一个基环树的常用操作:拓扑排序求环。具体方法是:在基环树上拓扑排序,然后拓扑序列中不存在的节点就是环中的节点了。
最后要用到环中的边的时候有一个小技巧,就是存边的时候(我用的是邻接表存双向边)按
input(x,y,z);
if(x>y) swap(x,y);
add(x,y,z);add(y,x,z);
的顺序存。
这样找边去重的时候就比较好找。。。(我也表述不太明白,具体看代码吧~)
Code
#include<iostream>
#include<cstdio>
#include<queue>
using namespace std;
const int N = 1e5+1;
int n,m,r[N];
int h[N],cnt,delu,delv;//假装 del_u-v 这条边已经被删去了qwq
struct edge
{
int nxt;
int to;
}e[N];
int ans[N],ans1[N];
int qh=0,qt=1,qtp[N],tp[N],vis[N],visu[N],visv[N],tpcnt;//巨丑的代码qwq
inline void readx(int &x)
{
x=0;char ch=getchar();
while(ch<'0'||ch>'9') ch=getchar();
while(ch>='0'&&ch<='9') {x=(x<<1)+(x<<3)+ch-48;ch=getchar();}
}
inline void add(register int u,register int v)
{
e[++cnt].nxt=h[u];
e[cnt].to=v;
h[u]=cnt;
}
inline void topo()
{
for(register int i=1;i<=n;++i) vis[i]=1;
for(register int u=1;u<=n;++u)
{
for(register int i=h[u];i;i=e[i].nxt)
{
register int v=e[i].to;
++tp[u];++tp[v];
}
}
for(register int i=1;i<=n;++i) if(tp[i]==2) qtp[qt++]=i;
// for(int i=1;i<=n;++i) printf("%d ",qtp[i]);printf("\n");
while(qt>qh)
{
register int u=qtp[++qh];vis[u]=0;
for(register int i=h[u];i;i=e[i].nxt)
{
register int v=e[i].to;
tp[u]-=2;tp[v]-=2;
if(tp[v]==2&&vis[v]) qtp[qt++]=v;
}
}
for(register int u=1;u<=n;++u)
if(vis[u]==1)
{
for(register int i=h[u];i;i=e[i].nxt)
{
register int v=e[i].to;
if(vis[v]==1&&u<v)
{
visu[++tpcnt]=u;visv[tpcnt]=v;
}
}
}
}
inline void update()
{
for(register int i=1;i<=n;++i)
{
if(ans1[i]==ans[i]) continue;
if(ans[i]==0) {for(register int j=1;j<=n;++j) ans[j]=ans1[j];return;}
if(ans1[i]>ans[i]) return;
//ans1[i]<ans[i]
for(register int j=i;j<=n;++j) ans[j]=ans1[j];return;
}
}
inline void dfs(register int u,register int fa)
{
ans1[++cnt]=u;
priority_queue <int,vector<int>,greater<int> > q;//小根堆
for(register int i=h[u];i;i=e[i].nxt)
{
register int v=e[i].to;
if(v==fa||(u==delu&&v==delv)||(u==delv&&v==delu)) continue;
q.push(v);
}
while(!q.empty())
{
register int v=q.top();q.pop();
dfs(v,u);
}
}
signed main()
{
readx(n);readx(m);
for(register int i=1;i<=m;++i)
{
int u,v;readx(u);readx(v);
if(u>v) swap(u,v);
add(u,v);add(v,u);
}
cnt=0;
if(m==n-1)
{
dfs(1,0);
for(register int i=1;i<=n;++i) ans[i]=ans1[i];
}
else
{
topo();
for(register int i=1;i<=tpcnt;++i)
{
cnt=0;
delu=visu[i];delv=visv[i];
dfs(1,0);
update();
}
}
for(register int i=1;i<=n;++i)
printf("%d ",ans[i]);
return 0;
}
其实代码也就是看106行到107行那里,别的地方写得太丑了没法看,而且自己基本能写出来,加油哦qwq!
NOIP2019 旅行的更多相关文章
- 【NOIP2019模拟2019.11.13】旅行 && GDKOI2018 还念(二分答案+dij)
Description: 题解: 显然满足二分性. 并且每一条边要不选l要不选r. 二分的那条链肯定要选l. 考虑有两个人在走最短路,一个人一开始必须走二分的那条链,要求第一个人走的比第二个人快. 安 ...
- BZOJ 3531: [Sdoi2014]旅行 [树链剖分]
3531: [Sdoi2014]旅行 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 1685 Solved: 751[Submit][Status] ...
- vijos P1780 【NOIP2012】 开车旅行
描述 小\(A\)和小\(B\)决定利用假期外出旅行,他们将想去的城市从\(1\)到\(N\)编号,且编号较小的城市在编号较大的城市的西边,已知各个城市的海拔高度互不相同,记城市\(i\)的海拔高度为 ...
- 【BZOJ-1570】BlueMary的旅行 分层建图 + 最大流
1570: [JSOI2008]Blue Mary的旅行 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 388 Solved: 212[Submit ...
- codevs 1036 商务旅行(Targin求LCA)
传送门 Description 某首都城市的商人要经常到各城镇去做生意,他们按自己的路线去做,目的是为了更好的节约时间. 假设有N个城镇,首都编号为1,商人从首都出发,其他各城镇之间都有道路连接,任意 ...
- nyoj 71 独木舟上的旅行(贪心专题)
独木舟上的旅行 时间限制:3000 ms | 内存限制:65535 KB 难度:2 描述 进行一次独木舟的旅行活动,独木舟可以在港口租到,并且之间没有区别.一条独木舟最多只能乘坐两个人,且乘客 ...
- 【bzoj3531】 [SDOI2014]旅行
题目描述 S国有N个城市,编号从1到N.城市间用N-1条双向道路连接,满足从一个城市出发可以到达其它所有城市.每个城市信仰不同的宗教,如飞天面条神教.隐形独角兽教.绝地教都是常见的信仰.为了方便,我们 ...
- tomcat源码分析(三)一次http请求的旅行-从Socket说起
p { margin-bottom: 0.25cm; line-height: 120% } tomcat源码分析(三)一次http请求的旅行 在http请求旅行之前,我们先来准备下我们所需要的工具. ...
- 11.14 T2 小x的旅行(小x的旅行)
1.小x的旅行 (travel.pas/c/cpp) [问题描述] 小x大学毕业后,进入了某个公司做了高层管理,他每年的任务就是检查这个公司在全国各地N个分公司的各种状况,每个公司都要检查一遍,且 ...
随机推荐
- 放眼全球,关注游戏质量变化:腾讯WeTest发布《2019中国移动游戏质量白皮书》
2019是中国游戏市场,尤其是手游市场称得上是跌宕起伏的一年,同时也是各大厂商推陈出新突破过去的一年.面对竞争激烈的市场,手游厂商们不仅着眼于游戏质量的提升,更是将一众优秀的国产游戏带入到了海外市场, ...
- 洛谷P1064 金明的预算方案(01背包)
题目描述 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间金明自己专用的很宽敞的房间.更让他高兴的是,妈妈昨天对他说:“你的房间需要购买哪些物品,怎么布置,你说了算,只要不超过NNN元钱就行” ...
- js兼容安卓和IOS的复制文本到剪切板
1.在做点击按钮复制功能时遇到了小小的卡顿,此处遇到了两种系统手机的兼容性 / 复制后会对文本进行选中 / 输入法弹出 等.现将方法进行总结,如下代码很好对解决了以上问题,适用性强. 2.在文本此处使 ...
- JVM 初始
我们刚学习java的时候,从来没有想过new一个对象后,需要我们手动去管理过他的内存空间释放,因为我们知道java有GC垃圾回收器这哥们的存在,他会帮我们处理好一切,这就好比我是皇帝,我想在哪建个行宫 ...
- 主机与虚拟机连接,主机能ping通虚拟机虚拟机ping不通主机问题
事件描述: 从物理主机ping虚拟机时,能正常返回信息.反之,从虚机ping物理主机时返回信息:Destination Host unreachable. 解决方法: 首先,是因为默认创建的虚拟机 ...
- Computational Complexity of Fibonacci Sequence / 斐波那契数列的时空复杂度
Fibonacci Sequence 维基百科 \(F(n) = F(n-1)+F(n-2)\),其中 \(F(0)=0, F(1)=1\),即该数列由 0 和 1 开始,之后的数字由相邻的前两项相加 ...
- 「JSOI2013」哈利波特和死亡圣器
「JSOI2013」哈利波特和死亡圣器 传送门 首先二分,这没什么好说的. 然后就成了一个恒成立问题,就是说我们需要满足最坏情况下的需求. 那么显然在最坏情况下伏地魔是不会走回头路的 因为这显然是白给 ...
- 使用在线编辑 svg 软件修改 svg 图片
网站需要使用图标字体,但设计师给的图标大小有问题,故使用下面说陈述方法简单修改了一下.使用到的在线编辑软件地址为:https://editor.method.ac/ 问题: 注:至于如何使用图标字体( ...
- Python识别验证码,基于Tesseract实现图片文字识别
一.简介 Tesseract是一个开源的文本识别[OCR]引擎,可通过Apache 2.0许可获得.它可以直接使用,或者使用API从图像中提取打印的文本,支持多种语言.该软件包包含一个ORC引擎[li ...
- 鸡汤 - Choice is yours
传送门 https://kamranahmed.info/blog/2018/03/24/choice-is-yours/ Our whole lives are driven by the choi ...