题目链接

随机化 暴力:

随便从一个点开始DFS,每次从之前得到的f[i]最大的子节点开始DFS。f[i]为从i开始(之前)能得到的最大答案。

要注意的是f[i]应当有机会从更小的答案更新,

9.10求直径。

就82分了。

本来想的SPFA啥的也不对。。正解思路是这的

#include <ctime>
#include <cstdio>
#include <cctype>
#include <vector>
#include <cstring>
#include <algorithm>
#define gc() getchar()
const int N=10005,M=2e4+5; int n,m,Max,pos,A[N],Enum,H[N],nxt[M],to[M],f[N];
bool vis[N];
std::vector<int> ans,tmp,ANS; inline int read()
{
int now=0;register char c=gc();
for(;!isdigit(c);c=gc());
for(;isdigit(c);now=now*10+c-'0',c=gc());
return now;
}
inline void AddEdge(int u,int v){
to[++Enum]=v, nxt[Enum]=H[u], H[u]=Enum;
to[++Enum]=u, nxt[Enum]=H[v], H[v]=Enum;
}
void DFS(int x)
{
vis[x]=1, tmp.push_back(x);
int way=0;
for(int i=H[x]; i; i=nxt[i])
if(!vis[to[i]]&&f[way]<f[to[i]]) way=to[i];
if(way) DFS(way);
}
void Solve()
{
memset(f,0,sizeof f);
for(int t=500; t; --t)
for(int i=1; i<=n; ++i)
{
memset(vis,0,sizeof vis), tmp.clear(), DFS(i);
if(tmp.size()>ans.size()) ans=tmp;
// if(tmp.size()>f[i]) f[i]=tmp.size();
if(tmp.size()>f[i]||rand()%15==0) f[i]=tmp.size();
}
if(ans.size()>ANS.size()) ANS=ans;
}
namespace Spec
{
int Max,v,pre[N]; void DFS(int x,int f,int d)
{
if(d>Max) Max=d, v=x;
for(int i=H[x]; i; i=nxt[i])
if(to[i]!=f) pre[to[i]]=x, DFS(to[i],x,d+1);
}
void Solve()
{
Max=0, DFS(1,1,1);
int u=v;
Max=0, DFS(v,v,1);
printf("%d\n%d\n",Max,v);
while(v!=u) printf("%d\n",v=pre[v]);
}
} int main()
{
// freopen("guide.in","r",stdin);
// freopen("guide.out","w",stdout); srand(time(NULL));
n=read(),m=read();
for(int i=1; i<=m; ++i) AddEdge(read(),read());
// Spec::Solve(); return 0;//9.10
for(int T=1; T<=15; ++T) Solve();
printf("%d\n",ANS.size());
for(int i=0; i<ANS.size(); ++i) printf("%d\n",ANS[i]); return 0;
}

正解:

可以先随机生成一棵树,然后去求它的直径。

想要这棵树的直径尽量大,它上面的点的度数应尽量小(要不大概就是很多分叉那样)。

枚举/随机一个根节点x,从它开始DFS,每次优先走度数最小的点v(注意把它相连的点的度数-1),连树上的边x->v。

DFS完这个度数最小的点v后,可以从x再走其它未访问的点,扩展树。

#include <ctime>
#include <cstdio>
#include <cctype>
#include <cstring>
#include <algorithm>
#define gc() getchar()
const int N=10005,M=2e4+5; int n,m,Max,V,pre[N],Enum,H[N],nxt[M],to[M],_Enum,_H[N],_nxt[M],_to[M],Dgr[N],dgr[N],ans[N];
bool vis[N]; inline int read()
{
int now=0;register char c=gc();
for(;!isdigit(c);c=gc());
for(;isdigit(c);now=now*10+c-'0',c=gc());
return now;
}
inline void AddEdge(int u,int v){
++Dgr[u], to[++Enum]=v, nxt[Enum]=H[u], H[u]=Enum;
++Dgr[v], to[++Enum]=u, nxt[Enum]=H[v], H[v]=Enum;
}
inline void AddTree(int u,int v){
_to[++_Enum]=v, _nxt[_Enum]=_H[u], _H[u]=_Enum;
_to[++_Enum]=u, _nxt[_Enum]=_H[v], _H[v]=_Enum;
}
void Build(int x)
{
vis[x]=1;
int way=0;
for(int i=H[x]; i; i=nxt[i]) --dgr[to[i]];
for(int i=H[x]; i; i=nxt[i])
if(!vis[to[i]]&&(dgr[way]>dgr[to[i]]||(dgr[way]==dgr[to[i]]&&rand()&1))) way=to[i];
// if(!vis[to[i]]&&dgr[way]>dgr[to[i]]) way=to[i];//略不对
if(way) AddTree(x,way), Build(way);
for(int i=H[x]; i; i=nxt[i])
if(!vis[to[i]]) AddTree(x,to[i]), Build(to[i]);
}
void DFS(int x,int f,int d)
{
if(d>Max) Max=d, V=x;
for(int i=_H[x]; i; i=_nxt[i])
if(_to[i]!=f) pre[_to[i]]=x, DFS(_to[i],x,d+1);
}
void Solve(int i)
{
_Enum=0, memset(_H,0,sizeof _H);
memset(vis,0,sizeof vis), memcpy(dgr,Dgr,sizeof dgr), Build(i);
Max=0, DFS(i,i,1);
int u=V;
Max=0, DFS(u,u,1);
if(Max>ans[0]){
ans[ans[0]=Max]=V;
while(V!=u) ans[--ans[0]]=V=pre[V];
ans[0]=Max;
}
} int main()
{
// freopen("guide.in","r",stdin);
// freopen("guide.out","w",stdout); srand(time(NULL));
n=read(),m=read();
for(int i=1; i<=m; ++i) AddEdge(read(),read());
Dgr[0]=1000000;
for(int T=10000; T; --T) Solve(rand()%n+1);//还是要多次
// for(int i=1; i<=n; ++i) Solve(i);
printf("%d\n",ans[0]);
for(int i=1; i<=ans[0]; ++i) printf("%d\n",ans[i]); return 0;
}

洛谷.4252.[NOI2006]聪明的导游(提答 直径 随机化)的更多相关文章

  1. 洛谷 P2504 [HAOI2006]聪明的猴子

    洛谷 P2504 [HAOI2006]聪明的猴子 题目描述 在一个热带雨林中生存着一群猴子,它们以树上的果子为生.昨天下了一场大雨,现在雨过天晴,但整个雨林的地表还是被大水淹没着,部分植物的树冠露在水 ...

  2. 【洛谷4252】[NOI2006] 聪明的导游(提答题)

    点此看题面 大致题意: 给你一张\(n\)个点.\(m\)条边的无向图,让你找出图上的一条不经过重复节点的最长路(提答+\(spj\)). 随机化乱搞 针对这种提答题,我们就要用随机化乱搞(Cptra ...

  3. 洛谷 P4397 [JLOI2014]聪明的燕姿 / TOPOI 测验1315, 问题E: 1935: 聪明的燕姿 解题报告

    题目链接 : 1. 洛谷 2.topoi . 大致题意:输入一个数s,找出所有约数和为s的数 关于一个数的约数和求法: 一个>1的整数可以被分解为多个 质数 的乘方,设数 s = p1k1 *  ...

  4. 洛谷 P4174 [NOI2006]最大获利 解题报告

    P4174 [NOI2006]最大获利 题目描述 新的技术正冲击着手机通讯市场,对于各大运营商来说,这既是机遇,更是挑战.THU 集团旗下的 CS&T 通讯公司在新一代通讯技术血战的前夜,需要 ...

  5. 洛谷 P4297 [NOI2006]网络收费

    P4297 [NOI2006]网络收费 题目背景 noi2006 day1t1 题目描述 网络已经成为当今世界不可或缺的一部分.每天都有数以亿计的人使用网络进行学习.科研.娱乐等活动.然而,不可忽视的 ...

  6. 洛谷—— P2504 [HAOI2006]聪明的猴子

    P2504 [HAOI2006]聪明的猴子 题目描述 在一个热带雨林中生存着一群猴子,它们以树上的果子为生.昨天下了一场大雨,现在雨过天晴,但整个雨林的地表还是被大水淹没着,部分植物的树冠露在水面上. ...

  7. 洛谷——P2504 [HAOI2006]聪明的猴子

    P2504 [HAOI2006]聪明的猴子 题目描述 在一个热带雨林中生存着一群猴子,它们以树上的果子为生.昨天下了一场大雨,现在雨过天晴,但整个雨林的地表还是被大水淹没着,部分植物的树冠露在水面上. ...

  8. 【洛谷p1314】聪明的质监员

    聪明的质监员[题目链接] 有关算法: 二分答案: 但是你只二分答案是不够的,因为你check会炸,所以还要考虑前缀和: 首先假装我们的check已经写好了,main函数: int main() { n ...

  9. 洛谷P4204 [NOI2006]神奇口袋 数论

    正解:数论 解题报告: 传送门 第一次用\(\LaTeX\)和\(markdown\),,,如果出了什么锅麻烦在评论跟我港句QAQ \(1)x_{i}\)可以直接离散 \(2)y_{i}\)的顺序对结 ...

随机推荐

  1. Qt多线程编程中的对象线程与函数执行线程

    近来用Qt编写一段多线程的TcpSocket通信程序,被其中Qt中报的几个warning搞晕了,一会儿是说“Cannot create children for a parent that is in ...

  2. 20165320 实验一 java环境的熟悉

    实验内容与步骤 一.java开发环境的熟悉 1.建立一个有关自己学号的目录 2.在当前文件下编译一个带包Hello.java文件 3.代码内容 package sq; import java.util ...

  3. Python——列表的操作

    列表的操作:详细+易出错假设有两个列表:    list1 = [1,2,3]    list2 = ['a','b','c']列表的操作: 1.list.append()    append只接受一 ...

  4. gcc编译选项【转】

    转自:https://blog.csdn.net/rheostat/article/details/19811407 常用选项 -E:只进行预处理,不编译-S:只编译,不汇编-c:只编译.汇编,不链接 ...

  5. Gitlab权限管理

    使用管理员登陆gitlab(版本为8.9)创建一个组 给用户授权 创建新用户 再创建两个dev1和dev2 然后再到项目界面授权给pm授权master 创建库(事先先建一个java组) 设置权限 创建 ...

  6. 01 Go 1.1 Release Notes

    Go 1.1 Release Notes Introduction to Go 1.1 Changes to the language Integer division by zero Surroga ...

  7. 数据库-mysql事务

    MySQL 事务 MySQL 事务主要用于处理操作量大,复杂度高的数据.比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数 ...

  8. git —— bug分支

    储藏工作现场 $ git stash 切换到需要修改bug的分支,创建临时分支 修复bug,修复完提交 修复完之后,切换到需要修改的分支.完成合并 合并后删除临时分支 完成后,可以重新回到没有修改完的 ...

  9. 浅谈C#中的值类型和引用类型

    在C#中,值类型和引用类型是相当重要的两个概念,必须在设计类型的时候就决定类型实例的行为.如果在编写代码时不能理解引用类型和值类型的区别,那么将会给代码带来不必要的异常.很多人就是因为没有弄清楚这两个 ...

  10. Asp.net Vnext 模块化实现

    概述 本文已经同步到<Asp.net Vnext 系列教程 >中] 在程序中实现模块化可以加快开发效率,通过替换模块实现升级. 架构 vnext 没有 Virtualpathprovide ...