$Luogu$

$Description$

一个$n$个点,$m$条边的图.$m=n-1$或$m=n$.任意选取一点作为起始点,可以去往一个没去过的点,或者回到第一次到达这个点时来自的点.要求遍历整个图,会得到一个遍历的点的序列(按照到达的先后顺序排).输出字典序最小的序列.

$Sol$

首先$m=n-1$也就是树的情况十分简单,选取$1$结点作为根,然后类似与$dfs$地往下遍历,只要每次选择子结点里字典序最小的那个走就好.$60get.$

$m=n$,就是一个带一个环的树,显然有一条边一定不会被走到.所以只要枚举环里的一条边删去,然后按树的做就好了.

$Code$

#include<iostream>
#include<cstdio>
#include<cstring>
#include<vector>
#include<algorithm>
#define il inline
#define Rg register
#define go(i,a,b) for(Rg int i=a;i<=b;++i)
#define yes(i,a,b) for(Rg int i=a;i>=b;--i)
#define mem(a,b) memset(a,b,sizeof(a))
#define u(i) b[i].u
#define v(i) b[i].v
#define ll long long
#define db double
#define inf 2147483647
using namespace std;
il int read()
{
Rg int x=,y=;char c=getchar();
while(c<''||c>''){if(c=='-')y=-;c=getchar();}
while(c>=''&&c<=''){x=(x<<)+(x<<)+c-'';c=getchar();}
return x*y;
}
const int N=;
int n,m,as[N],ans[N],tmp[N],ct,ct1,x,y;
struct node{int u,v;}b[N],h[N];
bool vis[N];
vector<int>q[N];
il void dfs1(int u,int fa)
{
as[++ct]=u;
go(i,,(int)q[u].size()-)
{
Rg int v=q[u][i];
if(v==fa)continue;
dfs1(v,u);
}
}
il bool dfs2(int u,int fa)
{
vis[u]=;
go(i,,(int)q[u].size()-)
{
Rg int v=q[u][i];
if(v==fa)continue;
if(vis[v]){h[++ct1]=(node){u,v};return ;}
if(dfs2(v,u)){h[++ct1]=(node){u,v};return ;}
}
return ;
}
il void dfs3(int u,int fa)
{
as[++ct]=u;
go(i,,(int)q[u].size()-)
{
Rg int v=q[u][i];
if(v==fa)continue;
if(u==x && v==y)continue;
if(u==y && v==x)continue;
dfs3(v,u);
}
}
int main()
{
n=read(),m=read();
go(i,,m)b[i]=(node){read(),read()};
go(i,,m)q[u(i)].push_back(v(i)),q[v(i)].push_back(u(i));
go(i,,n)sort(q[i].begin(),q[i].end());
if(m==n-)
{
dfs1(,);
go(i,,ct)printf("%d ",as[i]);
return ;
}
vis[]=;dfs2(,);
go(i,,ct1)if(h[i].v==h[].v){ct1=i-;break;}
go(i,,ct1)
{
x=h[i].u,y=h[i].v;ct=;
dfs3(,);
if(ans[]==)go(i,,n)ans[i]=as[i];
else
{
bool fl=;
go(j,,ct)
if(as[j]<ans[j]){fl=;break;}
else if(as[j]>ans[j]){break;}
if(fl)go(j,,n)ans[j]=as[j];
}
}
go(i,,n)printf("%d ",ans[i]);
return ;
}

随机推荐

  1. tinyhttpd简介

    一:简介: tinyhttpd是由J. DavidBlackstone在1999年编写的,实现了一个很简单的web服务器.支持GET和POST方法,总代码量也就在500行左右,可以用来学习HTTP协议 ...

  2. Samba服务器 安装

    yum -y install samba cp /etc/samba/smb.conf /etc/samba/smb.conf.bak cat >> /etc/samba/smb.conf ...

  3. hdu 1596 find the safest road (变形SP && dij+heap)

    Problem - 1596 变形最短路问题,给出邻接矩阵,要求求出给定点对间安全率最大值. 这题可以用dijkstra+heap来做.对于每一个查询,做一次dij即可. 代码如下: #include ...

  4. C# POST 表单发送文件

    表单提交协议规定:要先将 HTTP 要求的 Content-Type 设为 multipart/form-data,而且要设定一个 boundary 参数,这个参数是由应用程序自行产生,它会用来识别每 ...

  5. C++ sort使用两个参数来排序

    排序在编程中经常用到,冒泡法排序时间复杂度高,使用C++库函数sort可以快速排序. 1.必须的头文件#include < algorithm>和using namespace std;  ...

  6. Keras框架下的保存模型和加载模型

    在Keras框架下训练深度学习模型时,一般思路是在训练环境下训练出模型,然后拿训练好的模型(即保存模型相应信息的文件)到生产环境下去部署.在训练过程中我们可能会遇到以下情况: 需要运行很长时间的程序在 ...

  7. mac上的mysql管理工具sequel pro

    https://blog.csdn.net/wan_zaiyunduan/article/details/54909389 以前用过Plsql.Navicat.Workbench,现在换到mac上,用 ...

  8. jquery实用应用之jquery操作radio、checkbox、select

    本文收集一些jquery的实用技巧,非常实用的哦,其中对radio.checkbox.select选中与取值的方法. 获取一组radio被选中项的值var item = $('input[@name= ...

  9. js原生继承几种方式

    js原生继承 js本身并没有继承和类的概念,本质上是通过原型链(prototype)的形式实现的. 1.先写两个构造函数Parent和Child,用于将Child继承Parent function P ...

  10. 2006年NOIP普及组复赛题解

    题目涉及算法: 明明的随机数:简单模拟: 开心的金明:01背包: Jam的计数法:模拟: 数列:二进制. 明明的随机数 题目链接:https://www.luogu.org/problem/P1059 ...