BZOJ 1023: [SHOI2008]cactus仙人掌图 | 在仙人掌上跑DP
题目:
求仙人掌直径
http://www.lydsy.com/JudgeOnline/problem.php?id=1023
题解:
首先给出仙人掌的定义:满足所有的边至多在一个环上的无向联通图
我们先考虑一下如何求一棵树的直径
1.维护以每个节点的为根的子树中,以根为一条路径端点的最长路和次长路,
#include<cstdio>
#include<algorithm>
#include<cstring>
#define N 50005
using namespace std;
inline int read()
{
int ret=,neg=;char j=getchar();
for (;j>'' || j<'';j=getchar()) if (j=='-') neg=-;
for (;j>='' && j<='';j=getchar()) ret=ret*+j-'';
return ret*neg;
}
int n,m,ecnt,ind,ans;
int head[N],deep[N],f[N],low[N],dfn[N],fa[N];
int a[*N],q[*N],l,r;
struct adj{int v,nxt;}e[*N];
void add(int u,int v)
{
e[++ecnt].v=v;e[ecnt].nxt=head[u];head[u]=ecnt;
e[++ecnt].v=u;e[ecnt].nxt=head[v];head[v]=ecnt;
}
void dp(int root,int x)
{
int tot=deep[x]-deep[root]+;
for (int i=x;i!=root;i=fa[i])
a[tot--]=f[i];
a[tot]=f[root];
tot=deep[x]-deep[root]+;
for (int i=;i<=tot;i++) a[i+tot]=a[i];
q[]=;l=r=;
for (int i=;i<=*tot;i++)
{
while (l<=r && i-q[l]>tot/) l++;
ans=max(ans,a[i]+i+a[q[l]]-q[l]);
while (l<=r && a[q[r]]-q[r]<=a[i]-i) r--;
q[++r]=i;
}
for (int i=;i<=tot;i++)
f[root]=max(f[root],a[i]+min(i-,tot-i+));
}
void dfs(int x)
{
low[x]=dfn[x]=++ind;
for (int i=head[x],v;i;i=e[i].nxt)
if (e[i].v!=fa[x])
{
if (!dfn[v=e[i].v])
{
fa[v]=x;deep[v]=deep[x]+;
dfs(v);
low[x]=min(low[x],low[v]);
}
else low[x]=min(low[x],dfn[v]);
if (dfn[x]<low[v])
ans=max(ans,f[x]+f[v]+),f[x]=max(f[x],f[v]+);
}
for (int i=head[x],v;i;i=e[i].nxt)
if (fa[v=e[i].v]!=x && dfn[x]<dfn[v])
dp(x,v);
}
int main()
{
n=read();m=read();
for (int i=;i<=m;i++)
{
int k=read(),x=read();
for (int i=;i<=k;i++)
{
int y=read();add(x,y);x=y;
}
}
dfs();
printf("%d\n",ans);
return ;
}
BZOJ 1023: [SHOI2008]cactus仙人掌图 | 在仙人掌上跑DP的更多相关文章
- bzoj 1023: [SHOI2008]cactus仙人掌图 tarjan缩环&&环上单调队列
1023: [SHOI2008]cactus仙人掌图 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 1141 Solved: 435[Submit][ ...
- 【刷题】BZOJ 1023 [SHOI2008]cactus仙人掌图
Description 如果某个无向连通图的任意一条边至多只出现在一条简单回路(simple cycle)里,我们就称这张图为仙人掌图(cactus).所谓简单回路就是指在图上不重复经过任何一个顶点的 ...
- bzoj 1023: [SHOI2008]cactus仙人掌图 2125: 最短路 4728: 挪威的森林 静态仙人掌上路径长度的维护系列
%%% http://immortalco.blog.uoj.ac/blog/1955 一个通用的写法是建树,对每个环建一个新点,去掉环上的边,原先环上每个点到新点连边,边权为点到环根的最短/长路长度 ...
- bzoj 1023 [SHOI2008]cactus仙人掌图 ( poj 3567 Cactus Reloaded )——仙人掌直径模板
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1023 http://poj.org/problem?id=3567 因为lyd在讲课,所以有 ...
- bzoj 1023: [SHOI2008]cactus仙人掌图
这道题是我做的第一道仙人掌DP,小小纪念一下…… 仙人掌DP就是环上的点环状DP,树上的点树上DP.就是说,做一遍DFS,DFS的过程中处理出环,环上的点先不DP,先把这些换上的点的后继点都处理出来, ...
- BZOJ.1023.[SHOI2008]cactus仙人掌图(DP)
题目链接 类似求树的直径,可以用(类似)树形DP求每个点其子树(在仙人掌上就是诱导子图)最长链.次长链,用每个点子节点不同子树的 max{最长链}+max{次长链} 更新答案.(不需要存次长链,求解过 ...
- bzoj 1023: [SHOI2008]cactus仙人掌图【tarjan+dp+单调队列】
本来想先求出点双再一个一个处理结果写了很长发现太麻烦 设f[u]为u点向下的最长链 就是再tarjan的过程中,先照常处理,用最长儿子链和次长儿子链更新按ans,然后处理以这个点为根的环,也就是这个点 ...
- 【BZOJ1023】仙人掌图(仙人掌,动态规划)
[BZOJ1023]仙人掌图(仙人掌,动态规划) 题面 BZOJ 求仙人掌的直径(两点之间最短路径最大值) 题解 一开始看错题了,以为是求仙人掌中的最长路径... 后来发现看错题了一下就改过来了.. ...
- 1023: [SHOI2008]cactus仙人掌图 - BZOJ
Description如果某个无向连通图的任意一条边至多只出现在一条简单回路(simple cycle)里,我们就称这张图为仙人图(cactus).所谓简单回路就是指在图上不重复经过任何一个顶点的回路 ...
随机推荐
- web pack
WebPack是模块捆绑器,如果你的代码跨越了不同模块(例如不同Javascript文件),web pack可以将这些零散的代码构建到浏览器可读单个文件中. web pack还可以作为构建通道,你可以 ...
- Apache Maven(三):POM
什么是 POM? POM (Project Object Model) 项目对象模型.它是一个XML文件,其中包含有关Maven用于构建项目的项目和配置细节的信息.它包含大多数项目的默认值.例如,构建 ...
- spring-boot整合ehcache实现缓存机制
EhCache 是一个纯Java的进程内缓存框架,具有快速.精干等特点,是Hibernate中默认的CacheProvider. ehcache提供了多种缓存策略,主要分为内存和磁盘两级,所以无需担心 ...
- unity独立游戏开发日志2018/09/26
最近太忙,今天吃饭的时候灵感一现...想到了随机地图生成的方法,不过可能实现的比较笨...还需要优化,大佬绕过. 注释没打,最后统一解释. using System.Collections; usin ...
- R语言学习笔记(十二):零碎知识点(31-35)
31--round(),floor()和ceiling() round()四舍五入取整 floor()向下取整 ceiling()向上取整 > round(3.5) [1] 4 > flo ...
- C# 面试题 (一)
一.C# 理论 1.1.简述 private. protected. public. internal.protected internal 访问修饰符和访问权限 private : 私有成员, 在类 ...
- 【Consul】Consul架构-Consensus协议
Consul使用Consensus协议提供一致性(Consistency)--CAP定义的一致性.Consensus协议是基于"Raft:In search of an Understand ...
- GreenMail邮件测试服务器
GreenMail邮件测试服务器 http://blog.csdn.net/jackiehff/article/details/8741988 这个目前没有需求,所以暂不研究
- 【BZOJ 1269】文本编辑器
题目 这些日子,可可不和卡卡一起玩了,原来可可正废寝忘食的想做一个简单而高效的文本编辑器.你能帮助他吗?为了明确任务目标,可可对"文本编辑器"做了一个抽象的定义: Move k:将 ...
- Jmeter学习(三)
Apache JMeter是Apache组织开发的基于Java的压力测试工具.用于对软件做压力测试,它最初被设计用于Web应用测试,但后来扩展到其他测试.(来自百度) jmeter的特点: 开源免费. ...