【luogu P5022 旅行】 题解

题目连接:https://www.luogu.org/problemnew/show/P5022

\(NOIP2018 DAY2T1\)

考场上只写了60分,很容易想到当 m = n - 1 时的树的做法。

读题推一下样例不难发现,如果选择一个分支节点就必须走到头——直到一个节点没有子树。

那么我们就可以贪心的求得最小字典序序列,每次选择节点编号最小的走。

即对当前节点的所有子节点排序选择最小编号的往下进行即可。

60分code:

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int maxn = 5010;
struct edge{int to, next;
}e[maxn<<2];
int head[maxn], cnt, n, m;
bool vis[maxn];
void add(int u, int v)
{e[++cnt].to = v; e[cnt].next = head[u]; head[u] = cnt;
}
void dfs(int x)
{if(vis[x]) return;vis[x] = 1;printf("%d ",x);int a[maxn], num = 0;for(int i = 1; i <= n; i++) a[i] = 0;for(int i = head[x]; i != -1; i = e[i].next)a[++num] = e[i].to;sort(a+1, a+1+num);for(int i = 1; i <= num; i++)dfs(a[i]);
}
int main()
{memset(head, -1, sizeof(head));scanf("%d%d",&n,&m);for(int i = 1; i <= m; i++){int u, v;scanf("%d%d",&u,&v);add(u, v);add(v, u);}dfs(1);return 0;
}

100分做法:

考虑 m = n 这个情况,树多加一条边(无自环重边情况下)会变成一个环套树。

环套树有一个性质是删去环上的一边就会成为一棵树。

那么当是一棵树的时候,我们能找到一个最优解,当 m = n 时,我们就可以找出多棵树的最优解,在这些最优解中选取一个最优的最优解,就是 m = n 时的最优解。

所以我们只需要把这多棵树的最优解找出来就行了。

所以我们需要把环上的边枚举断掉使原图成为一棵树再进行60分的做法。

考虑数据范围<=5000,N^2暴力断边即可。

code:

#include <vector>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int maxn = 5010;
struct edge{int to, next;
}e[maxn<<2];
int head[maxn], cnt, n, m, u[maxn], v[maxn];
bool vis[maxn];
void add(int u, int v)
{e[++cnt].to = v; e[cnt].next = head[u]; head[u] = cnt;
}
void dfs(int x)
{if(vis[x]) return;vis[x] = 1;printf("%d ",x);int a[maxn], num = 0;for(int i = 1; i <= n; i++) a[i] = 0;for(int i = head[x]; i != -1; i = e[i].next)a[++num] = e[i].to;sort(a+1, a+1+num);for(int i = 1; i <= num; i++)dfs(a[i]);
}
//=======================
vector<int> E[maxn];
int ANS[maxn], NOW[maxn], TOT, CUTu, CUTv;
bool VIS[maxn];
void DFS(int x)
{if(VIS[x]) return;VIS[x] = 1;NOW[++TOT] = x;for(int i = 0; i < E[x].size(); i++){int y = E[x][i];if((y == CUTv && x == CUTu) || (x == CUTv && y == CUTu)) continue;DFS(y);}
}
bool check()
{for(int i = 1; i <= n; i++){if(ANS[i] == NOW[i]) continue;if(ANS[i] > NOW[i]) return 1;if(ANS[i] < NOW[i]) return 0;}
}
int main()
{memset(head, -1, sizeof(head));scanf("%d%d",&n,&m);for(int i = 1; i <= m; i++){scanf("%d%d",&u[i],&v[i]);add(u[i], v[i]);add(v[i], u[i]);E[u[i]].push_back(v[i]);E[v[i]].push_back(u[i]);}for(int i = 1; i <= n; i++) sort(E[i].begin(), E[i].end());if(m == n-1){dfs(1);return 0;}else{for(int i = 1; i <= m; i++){TOT = 0, CUTu = u[i], CUTv = v[i];memset(VIS, 0, sizeof(VIS));DFS(1);if(TOT == n){if(ANS[1] == 0){for(int j = 1; j <= n; j++)ANS[j] = NOW[j];}else if(check()){for(int j = 1; j <= n; j++)ANS[j] = NOW[j];}}}for(int i = 1; i <= n; i++)printf("%d ",ANS[i]);return 0;}
}

后记:

半退役选手回来的第二篇题解。

想想去年自己距离省一线差了10分,即使过去半年心里也依旧不是滋味。

DAY2考时想不起环套树来,考后出考场的一刹那就想到了可以N^2暴力断边。

其实环套树考前是讲过的,断边操作也是老师提到过的。

可是自己却总觉得环套树在NOIP比较冷门吧也没怎么去巩固练习。

可事后再去后悔再去抱怨终究是一点用都没有的。

转载于:https://www.cnblogs.com/MisakaAzusa/p/11002522.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/462361.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

面向对象编程从骨子里就有问题——看看名人大家是如何吐槽面向对象的

2019独角兽企业重金招聘Python工程师标准>>> 本文由“外刊IT评论”网(www.aqee.net)荣誉出品 “面向对象编程是一个极其糟糕的主意&#xff0c;只有硅谷里的人能干出这种事情。” — Edsger Dijkstra(图灵奖获得者) “面向对象设计是用罗马数字做计算。” — Ro…

花了两个星期,我终于把 WSGI 整明白了

在 三百六十行&#xff0c;行行转 IT 的现状下&#xff0c;很多来自各行各业的同学&#xff0c;都选择 Python 这门胶水语言做为踏入互联网大门的第一块敲门砖&#xff0c;在这些人里&#xff0c;又有相当大比例的同学选择了 Web 开发这个方向&#xff08;包括我&#xff09;。…

如何:通过现有代码创建 C++ 项目

http://msdn.microsoft.com/zh-cn/library/b9cy3d6x(vvs.90).aspx 如何&#xff1a;通过现有代码创建 C 项目 Visual Studio 2008其他版本2&#xff08;共 2&#xff09;对本文的评价是有帮助 - 评价此主题更新&#xff1a;2007 年 11 月 可以使用 “从现有代码文件创建新项目”…

JqueryCookie

https://github.com/carhartl/jquery-cookie/downloads转载于:https://www.cnblogs.com/mingyongcheng/archive/2011/12/09/2282613.html

ActiveReports 报表应用教程 (8)---交互式报表之动态过滤

用户可以使用葡萄城ActiveReports报表参数 (Parameters)集合把数据提供给报表中的文本框或图表&#xff0c;也可以选择数据的一个子集显示到报表的特定区域&#xff0c;或者是把数据从主报表象子报表传递。用户可以通过三种方式获取数据的值&#xff1a;提示用户输入&#xff1…

gSOAP学习笔记

网站:http://www.cppblog.com/pansunyou/archive/2013/08/05/137563.html gSOAP学习笔记 虽然SOAP被有些人说太老土&#xff0c;但在银行里仍有大量系统在使用&#xff0c;前段时间在工作中接触到&#xff0c;故记录一下。 gSOAP学习笔记 潘孙友 2010-12-27 于遵义 目录 一、基…

Scala实践6

1 if表达式 Scala中if...else..表达式是有返回值的&#xff0c;如果if和else返回值类型不一样&#xff0c;则返回Any类型。scala> val a310 a3: Int 10scala> val a4 | if(a3>20){ | "a3大于a4" | }else{ | "a4大于a3" | } a4: String a4大于a…

jquery ui autocomplete输入中文不自动完成的问题

因为输入法或浏览器的问题&#xff0c;在输入中文后并没有触发自动完成&#xff0c;要再按多一下键盘才触发&#xff0c;查看发现它是用keydown来实现.bind("keydown.autocomplete", function(event) {....})可以对其input事件进行监听来解决问题&#xff0c;在上面的…

【洛谷p1464】 Function

中考第一天&#xff1b; 感觉我超废&#xff1b; 就是看这道题特别顺眼emmm SOLUTION&#xff1a; 思路的话是开三维数组s[i][j][k]&#xff0c;先三重for循环预处理出s[0~20][0~20][0~20]的w(a,b,c)&#xff0c;然后直接搜索就好了。 Code&#xff1a; #include<bits/stdc.…

一个简单的高并发的回应服务器(5万并发)

一个简单的高并发的回应服务器&#xff0c;主要是使用boost的库&#xff01; 自己测试过可以达到5万个并发&#xff01; 程序的下载地址&#xff1a;http://download.csdn.net/detail/guanyijun123/8335907 #include <stdio.h> //#include "AuthenHandle.h" /…

delphi 的一些备忘

override&#xff1a;覆盖&#xff1b; overload&#xff1a;重载&#xff1b; Reintroduce&#xff1a;重定义&#xff0c;它的引入是为了屏蔽父类的一个虚方法,而在子类中生成一个新的方法; 其实你不使用reintroduce也会覆盖屏蔽父类的方法的但是会产生一个警告&#xff01; …

10.高效分布

ListView默认的分页是先从数据源取得所有数据&#xff0c;然后再截取当前页面的部分&#xff0c;在数据量非常大的情况下效率非常低&#xff0c;因此默认的分布基本不能用。应该是只从数据源取得要显示的数据即可。SQL中语句中取得分页数据的方法为&#xff1a;Select * ,ROW_N…

项目测试~

这个作业属于哪个课程 https://edu.cnblogs.com/campus/xnsy/SoftwareEngineeringClass2 这个作业要求在哪里 https://edu.cnblogs.com/campus/xnsy/SoftwareEngineeringClass2/homework/3340 团队名称 求莫名堂 作业的目标 学会进行项目的测试&#xff0c;并通过测试发…

boost_1_48_0 在VS2008下的安装 Boost.Asio安装

第一步&#xff1a;到官网www.boost.org&#xff0c;下载boost最新版boost_1_48_0.zip第二步&#xff1a;将boost压缩包解压到C盘根目录下(在C盘操作简单&#xff0c;不会出错)&#xff0c;目录为C:\BOOST_1_48_0,里面就是boost的源码和需要编译的文件及文档资料第三步&#xf…

线程----BlockingQueue

import java.util.concurrent.ArrayBlockingQueue;import java.util.concurrent.BlockingQueue;import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;/** 本例介绍一个特殊的队列:BlockingQueue,如果BlockQueue是空的,从BlockingQueue取东西…

D3D9 effect (hlsl)(转)

转:http://blog.csdn.net/leonwei/article/details/8212800 effect其实整合了shader和render state的控制两大部分内容 9.1 effect文件基本框架 part1 &#xff1a;shader state包括全局变量 shader数据结构定义&#xff0c;shader的实现 part2 &#xff1a;texture and sample…

boost_1.47在VS2010下的安装

第一步&#xff1a;到官网www.boost.org&#xff0c;下载boost最新版boost_1_47_0.zip第二步&#xff1a;将boost压缩包解压到C盘根目录下(在C盘操作简单&#xff0c;不会出错)&#xff0c;目录为C:\BOOST_1_47_0,里面就是boost的源码和需要编译的文件及文档资料第三步&#xf…

创建 WPF 不规则窗口

创建 WPF 不规则窗口 本文为khler原作&#xff0c;转载必须确保本文完整并完整保留原作者信息及本文原始链接  E-mail: khler163.com  QQ: 23381103  MSN: pragmachotmail.com   相对于用MFC创建不规则窗口&#xff0c;WPF创建不规则窗体的过程就显得相当享受了&…

公司运作 - 利润率、周转率

公司一般由市场部、研发部、财务部、人力资源部及其他辅助部门组成。分成了几个层面&#xff0c;如下&#xff1a; 宏观层面&#xff1a;业务范围、业务定位、专业化、多元化部门层面&#xff1a;各部门绩效、部门职责主体层面&#xff1a;跨部门事务&#xff0c;如产品研发涉及…

ffmpeg编解码详细过程

1. 注册所有容器格式和CODEC:av_register_all() 2. 打开文件:av_open_input_file() 3. 从文件中提取流信息:av_find_stream_info() 4. 穷举所有的流&#xff0c;查找其中种类为CODEC_TYPE_VIDEO 5. 查找对应的解码器:avcodec_find_decoder() 6. 打开编解码器:avcodec_open() 7.…