洛谷P5022 旅行(基环树+断环法)

简介: 洛谷P5022 旅行(基环树+断环法)

原题链接

题意:

一棵树,从1出发,每到达一个新的点就记录下编号。求一种走法使得记录下来的编号字典序最小。

思路:

题意里说m<=n,就说明这棵树可能是基环树。

如果这棵树是普通的树的话,直接排序后dfs一下,每次都走字典序最小的点。如果这棵树是基环树的话,首先要明确一个性质,环上肯定有一条边是不经过的,可以手动模拟一下过程。所以我们就可以每次枚举这条不经过的边,求答案后取字典序最小。这条边不经过的话,对答案是无影响的,可以确保正确性。

复杂度大概n*n,吸吸氧气就能过。

代码:

const int maxn=2e5+100;
int h[maxn],idx;
struct node{
    int u,v,ne;
}edge[maxn*2];
int n,m;
vector<int>g[maxn];
void add(int u,int v){
    edge[idx]={u,v,h[u]};h[u]=idx++;
}
int timetmp=0;
int res[maxn],tmp[maxn],vis[maxn];
void dfs(int u,int fa,int delu,int delv,int tmp[]){
    if(vis[u]) return ;
    vis[u]=1;
    tmp[++timetmp]=u;
    for(int i=0;i<g[u].size();i++){
        int t=g[u][i];
        if(t==fa) continue;
        if(t==delu&&u==delv) continue;///当前边是本次删除的边
        if(t==delv&&u==delu) continue;
        dfs(t,u,delu,delv,tmp);
    }
}
bool check(){
    for(int i=1;i<=n;i++)
        if(res[i]<tmp[i]) return 0;
        else if(res[i]>tmp[i]) return 1;//需要更改
}
int main(){
    memset(h,-1,sizeof h);
    n=read(),m=read();
    for(int i=1;i<=m;i++){
        int u=read(),v=read();
        add(u,v);add(v,u);
        g[u].push_back(v);
        g[v].push_back(u);
    }
    for(int i=1;i<=n;i++) sort(g[i].begin(),g[i].end());///对每个点的出边进行排序
    if(n==m){///基环树
        for(int i=0;i<idx;i+=2){///枚举删哪条边
            timetmp=0;
            memset(vis,0,sizeof vis);
            dfs(1,-1,edge[i].u,edge[i].v,tmp);
            if(timetmp<n) continue;///走不到所有的点
            if(res[1]==0||check()){
                for(int j=1;j<=n;j++) res[j]=tmp[j];///未被更新或是当前走法的字典序更小
            }
        }
    }
    else dfs(1,-1,-1,-1,res);
    for(int i=1;i<=n;i++) printf("%d ",res[i]);
  return 0;
}

参考:

目录
相关文章
|
1月前
|
C++
【状态压缩DP】 毕业旅行问题(C/C++)
【状态压缩DP】 毕业旅行问题(C/C++)
|
2月前
|
存储 UED
探索编程之美:一段代码的旅行
【9月更文挑战第12天】本文通过一个简单代码示例的逐步完善,展现了编程过程中的思考与学习。从最初的功能实现到性能优化,再到用户体验的提升,每一步都体现了编程的艺术和科学。文章旨在鼓励读者以创造性思维对待代码,发现编程的乐趣和挑战。
|
6月前
|
存储
每日一题——leetcode682.棒球比赛
每日一题——leetcode682.棒球比赛
|
6月前
|
存储 人工智能 测试技术
2020年第十一届蓝桥杯模拟赛解题报告
2020年第十一届蓝桥杯模拟赛解题报告
|
6月前
滑雪(蓝桥模拟赛的题)
滑雪(蓝桥模拟赛的题)
56 0
【寒假每日一题】AcWing 4455. 出行计划
目录 一、题目 1、原题链接 2、题目描述 二、解题报告 1、思路分析 2、时间复杂度 3、代码详解 三、知识风暴 差分与前缀和
116 0
|
11月前
滑雪(也是蓝桥模拟赛的题)
和蓝桥杯模拟赛的最大连通过差不多一个思想
48 0
【洛谷】独自一人听歌写题
【洛谷】独自一人听歌写题
73 0
|
存储 机器学习/深度学习 算法
【蓝桥杯集训·每日一题】AcWing 4074. 铁路与公路
文章目录 一、题目 1、原题链接 2、题目描述 二、解题报告 1、思路分析 2、时间复杂度 3、代码详解 三、知识风暴 Floyd 算法 Spfa 算法
110 0
|
C++
蓝桥杯2020省赛真题 作物杂交问题 C++
蓝桥杯2020省赛真题 作物杂交问题 C++
159 1
蓝桥杯2020省赛真题 作物杂交问题 C++