注意!注意!前方高能!本题卡常!!!

我们发现,所有的狗血剧情都在告诉我们,树的话直接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 旅行的更多相关文章

  1. 【NOIP2019模拟2019.11.13】旅行 && GDKOI2018 还念(二分答案+dij)

    Description: 题解: 显然满足二分性. 并且每一条边要不选l要不选r. 二分的那条链肯定要选l. 考虑有两个人在走最短路,一个人一开始必须走二分的那条链,要求第一个人走的比第二个人快. 安 ...

  2. BZOJ 3531: [Sdoi2014]旅行 [树链剖分]

    3531: [Sdoi2014]旅行 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 1685  Solved: 751[Submit][Status] ...

  3. vijos P1780 【NOIP2012】 开车旅行

    描述 小\(A\)和小\(B\)决定利用假期外出旅行,他们将想去的城市从\(1\)到\(N\)编号,且编号较小的城市在编号较大的城市的西边,已知各个城市的海拔高度互不相同,记城市\(i\)的海拔高度为 ...

  4. 【BZOJ-1570】BlueMary的旅行 分层建图 + 最大流

    1570: [JSOI2008]Blue Mary的旅行 Time Limit: 15 Sec  Memory Limit: 162 MBSubmit: 388  Solved: 212[Submit ...

  5. codevs 1036 商务旅行(Targin求LCA)

    传送门 Description 某首都城市的商人要经常到各城镇去做生意,他们按自己的路线去做,目的是为了更好的节约时间. 假设有N个城镇,首都编号为1,商人从首都出发,其他各城镇之间都有道路连接,任意 ...

  6. nyoj 71 独木舟上的旅行(贪心专题)

    独木舟上的旅行 时间限制:3000 ms  |  内存限制:65535 KB 难度:2   描述 进行一次独木舟的旅行活动,独木舟可以在港口租到,并且之间没有区别.一条独木舟最多只能乘坐两个人,且乘客 ...

  7. 【bzoj3531】 [SDOI2014]旅行

    题目描述 S国有N个城市,编号从1到N.城市间用N-1条双向道路连接,满足从一个城市出发可以到达其它所有城市.每个城市信仰不同的宗教,如飞天面条神教.隐形独角兽教.绝地教都是常见的信仰.为了方便,我们 ...

  8. tomcat源码分析(三)一次http请求的旅行-从Socket说起

    p { margin-bottom: 0.25cm; line-height: 120% } tomcat源码分析(三)一次http请求的旅行 在http请求旅行之前,我们先来准备下我们所需要的工具. ...

  9. 11.14 T2 小x的旅行(小x的旅行)

    1.小x的旅行   (travel.pas/c/cpp) [问题描述] 小x大学毕业后,进入了某个公司做了高层管理,他每年的任务就是检查这个公司在全国各地N个分公司的各种状况,每个公司都要检查一遍,且 ...

随机推荐

  1. eosio 编译与部署

    1. 名词解释 创世节点(BIOS) 用于创建初始区块,加载基础合约,供其它节点同步连接. 矿工节点(BP) 主要用于生产同步区块,计算合约产生的费用归矿工账号所有. 查询节点 不产生区块,同步区块信 ...

  2. 2019 EIS高校安全运维赛 misc webshell

    webshell 第一种思路: 1.菜刀都是http协议,发的包都是POST包,所以在显示过滤器下命令:http.request.method==POST 2.右键,追踪tcp流,发现是蚁剑流量 3. ...

  3. CentOS 7----Apache基于域名的虚拟主机配置

    配置/etc/hosts文件,192.168.1.209 对应的域名如下: 192.168.1.209 www.name1.com 编辑每个域名的配置文件: <VirtualHost 192.1 ...

  4. EntityFramework中使用sql语句

    https://blog.csdn.net/yangyangafan/article/details/77602133 EntityFramework操作数据库谜一般的方便还不用写数据库,但前提是很简 ...

  5. 学习JavaScript数据结构与算法---前端进阶系列

    学习建议 1.视频学习---认知 建议:在中国慕课上找"数据结构"相关的视频教程.中国大学MOOC 推荐清华大学.北京大学.浙江大学的教程,可先试看,然后根据自身的情况选择视频进行 ...

  6. Ubuntu 17.04 apt-get 获取失败

    最近电脑上的ubuntu apt-get 命令出现了异常,百度好久终于解决. 问题:sudo apt-get update命令执行  全部忽略或者是错误       一些文件也无法安装 解决办法:刚开 ...

  7. spark实验(二)--scala实验(3)

    实验1,计算级数: 首先打开安装完scala ide的eclipse,在eclipse 中新建一个scala project. 然后新建一个scala的object对象 导入scala.io.StdI ...

  8. systomctl与service的区别主要是版本区别

    redhat和centos在7及以后的版本,用systemctl命令 redhat和centos在6及6以前的版本,用service命令. 两者的区别,如下. 举例 这里的.service可以不写,如 ...

  9. Introducing .NET 5

    Today, we’re announcing that the next release after .NET Core 3.0 will be .NET 5. This will be the n ...

  10. JQuery常用CSS操作

    JQuery常用CSS操作 $(elem).css(obj):设置行内样式 $(elem).position():返回相对于父容器位置,只能获取不能设置 $(elem).offset(obj):返回相 ...