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个分公司的各种状况,每个公司都要检查一遍,且 ...
随机推荐
- C#: switch语句的重构『网摘』
http://bj007.blog.51cto.com/1701577/345100/ switch语句是我们日常工作中最常见也是争论最多的(goto被忽视的前提下).在重构中也把switch语句看成 ...
- zol验证码抓包
http://www.zol.com/detail/lcd/samsung/25254662.html?zp_from=pro_price_pricenode 网站’ http://city.zol. ...
- idea项目更改git地址
第一步:idea打开项目,菜单栏找VCS - Git - Remotes 点进去,弹出对话框,选中,点击编辑 弹出编辑框,更改地址,点击ok 弹出输入账号密码编辑框,输入自己的账号密码,点击确认 完成 ...
- vscode管理员身份运行
管理员身份运行,如vscode 如何设置呢? vscode图标右键 以管理员身份运行程序打钩就行了 运行“在终端打开”的时候,要以管理员身份运行 刚下载完vscode并运行并不是管理员身份会报错 解 ...
- 在tomcat上部署项目
1.部署项目的第一种方法(项目直接放入 webapps 目录中) 2.部署项目的第二种方法(修改 conf/server.xml 文件 ) 3.部署项目的第三种方法(apache-tomcat-7.0 ...
- ntpdate 设置时区(注意本地时区要设置正确)
修改timezone sudo cp -a /usr/share/zoneinfo/Etc/GMT-8 /etc/localtime date -R == 展示当前的timezone ntpda ...
- 4_5 追踪电子表格中的单元格(UVa512)(选做)
在电子表格中的数据都存储在单元格中,它是按行和列(R)(C).一些在电子表格上的操作可以应用于单个单元格(研发),而其他的可以应用于整个行或列.典型的单元操作包括插入和删除行或列和交换单元格内容.一些 ...
- Xcode创建子工程以及工程依赖
https://www.jianshu.com/p/f2bc7d155a86 阅读 7858 视频地址 如果文章不详细,点击看操作视频 项目需求:代码抽层,业务逻辑和数据处理要高度抽离,模块化,需要将 ...
- cmd创建用户开启3389命令
1.创建用户chen Net user chen 1234566 /add 2.将用户chen添加到管理员组 net localgroup Administrators chen /add 3.开启3 ...
- 绕过QQ群文件下载限速
绕过QQ群文件下载限速 引言 众所周知,用QQ客户端下载QQ群文件,速度往往被限为10KB/s.这里我们来讲讲如何绕过这一限制. 原始事件发生在2020年2月2日,值武汉疫情爆发,全国各省市纷纷下令推 ...