[SHOI2006]仙人掌

简要解析

其实很简单

只要普通树形 \(dp\) 就行了

\(f_x\) 表示 \(x\) 能向下延深的最大距离,\(v\) 是 \(x\) 的儿子

当一个点不属于任何环时 \(f_x = \max(f_v + 1)\)

这是更新 \(ans = \max(ans , f_x + f_v + 1)\)

只是带环的话,环要单独算

这是我们的直径可以不经过环顶端的点,直接选环中两个点 \(u,v\)

让 \(ans = \max(ans , f_u + f_v + dist_{u,v})\)

显然不能 \(n^2\) 枚举这两个环中点

因为要符合最短路,所以这两个点距离 \(dist_{u,v} \leq lim\),\(lim\) 为环长的一半

那么我们可以再 \(dp\) 求 \(f_u + f_v + dist_{u,v}\)

给 \(u,v\) 规定方向,从离环顶距离小的往大

于是破环成链再倍长,单调队列维护

\(Code\)

#include<cstdio>
#include<iostream>
using namespace std; const int N = 100005;
int n , m , tot , dfc;
int h[N] , dfn[N] , low[N] , fa[N] , f[N] , a[N] , q[N] , ans; struct edge{
int to , nxt;
}e[N << 1];
void add(int x , int y){e[++tot] = edge{y , h[x]} , h[x] = tot;} void solve(int x , int v)
{
int lim , cnt = 0 , h = 1 , r = 1;
for(register int i = v; i != fa[x]; i = fa[i]) a[++cnt] = f[i];
for(register int i = 1; i <= cnt; i++) a[i + cnt] = a[i];
lim = cnt >> 1 , q[1] = 1;
for(register int i = 2; i <= cnt * 2; i++)
{
while (h < r && i - q[h] > lim) h++;
ans = max(ans , i - q[h] + a[i] + a[q[h]]);
while (r >= h && a[q[r]] - q[r] <= a[i] - i) r--;
q[++r] = i;
}
for(register int i = 1; i <= cnt; i++) f[x] = max(f[x] , a[i] + min(i , cnt - i));
} void tarjan(int x)
{
dfn[x] = low[x] = ++dfc;
int v;
for(register int i = h[x]; i; i = e[i].nxt)
{
v = e[i].to;
if (v == fa[x]) continue;
if (!dfn[v]) fa[v] = x , tarjan(v) , low[x] = min(low[x] , low[v]);
else low[x] = min(low[x] , dfn[v]);
if (low[v] > dfn[x])
{
ans = max(ans , f[x] + f[v] + 1);
f[x] = max(f[x] , f[v] + 1);
}
}
for(register int i = h[x]; i; i = e[i].nxt)
if (fa[v = e[i].to] != x && dfn[v] > dfn[x]) solve(x , v);
} int main()
{
scanf("%d%d" , &n , &m);
int num , x , y;
for(register int i = 1; i <= m; i++)
{
scanf("%d%d" , &num , &x);
for(register int j = 2; j <= num; j++)
scanf("%d" , &y) , add(x , y) , add(y , x) , x = y;
}
tarjan(1);
printf("%d" , ans);
}

[SHOI2006]仙人掌的更多相关文章

  1. luogu P4129 [SHOI2006]仙人掌

    题目描述 仙人掌图(cactus)是一种无向连通图,它的每条边最多只能出现在一个简单回路(simple cycle)里面.从直观上说,可以把仙人掌图理解为允许存在回路的树.但是仙人掌图和树之间有个本质 ...

  2. 2018.10.29 洛谷P4129 [SHOI2006]仙人掌(仙人掌+高精度)

    传送门 显然求出每一个环的大小. Ans=∏i(siz[i]+1)Ans=\prod_i(siz[i]+1)Ans=∏i​(siz[i]+1) 注意用高精度存答案. 代码: #include<b ...

  3. 洛谷 P4244 [SHOI2008]仙人掌图 II 解题报告

    P4244 [SHOI2008]仙人掌图 II 题目背景 题目这个II是和SHOI2006的仙人掌图区分的,bzoj没有. 但是实际上还是和bzoj1023是一个题目的. 题目描述 如果某个无向连通图 ...

  4. bzoj1023: [SHOI2008]cactus仙人掌图

    学习了一下圆方树. 圆方树是一种可以处理仙人掌的数据结构,具体见这里:http://immortalco.blog.uoj.ac/blog/1955 简单来讲它是这么做的:用tarjan找环,然后对每 ...

  5. 【BZOJ 1023】【SHOI 2008】cactus仙人掌图

    良心的题解↓ http://z55250825.blog.163.com/blog/static/150230809201412793151890/ tarjan的时候如果是树边则做树形DP(遇到环就 ...

  6. 【BZOJ-1952】城市规划 [坑题] 仙人掌DP + 最大点权独立集(改)

    1952: [Sdoi2010]城市规划 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 73  Solved: 23[Submit][Status][ ...

  7. 【BZOJ-4316】小C的独立集 仙人掌DP + 最大独立集

    4316: 小C的独立集 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 57  Solved: 41[Submit][Status][Discuss] ...

  8. 仙人掌(cactus)

    仙人掌(cactus) Time Limit:1000ms Memory Limit:64MB 题目描述 LYK 在冲刺清华集训(THUSC) !于是它开始研究仙人掌,它想来和你一起分享它最近研究的 ...

  9. 【bzoj1023】仙人掌图

    [bzoj1023]仙人掌图 题意 给一棵仙人掌,求直径. \(n\leq 100000\) 分析 分析1:[Tarjan]+[环处理+单调队列优化线性dp]+[树形dp] 分开两种情况处理: ①环: ...

  10. hdu3594 强连通(仙人掌图)

    题意:给定一张有向图,问是否是仙人掌图.仙人掌图的定义是,首先,这张图是一个强连通分量,其次所有边在且仅在一个环内. 首先,tarjan可以判强连通分量是否只有一个.然后对于所有边是否仅在一个环内,我 ...

随机推荐

  1. CompletionService 使用小结

    本文为博主原创,转载请注明出处: 实现异步任务时,经常使用 FutureTask 来实现:一个简单的示例代码如下: public static void main(String[] args) thr ...

  2. 使用sanic框架实现分布式爬虫

    bee_server.py from sanic import Sanic from sanic import response from urlpool import UrlPool #初始化url ...

  3. 异常处理语法结构、yield生成器及其表达式

    今日内容回顾 目录 今日内容回顾 异常处理语法结构 异常处理实战应用 生成器对象 自定义range功能 yield冷门用法 yield与return对比 生成器表达式 笔试题 异常处理语法结构 异常处 ...

  4. python之路38 SQL注入问题 索引触发器 事务 存储过程 函数 流程控制

    SQL注入问题 怪像1:输对用户名就可以登录成功 怪像2:不需要对的用户名和密码也可以登录成功 SQL注入:利用特殊符号的组合产生特殊的含义 从而避开正常的业务逻辑 select * from use ...

  5. C# 如何发送邮件消息

    1.安装NUGET包 MailKit 2.代码如下 using MailKit.Net.Smtp; using MimeKit; using System.Collections.Generic; u ...

  6. Debian 软件包管理

    Debian 软件包管理 Debian 软件包管理 基础软件包管理知识 sources.list 文件格式 新手建议 档案库临时小故障 软件包依赖关系 APT 进行软件包管理 基本操作 软件包管理操作 ...

  7. Redefinition of 'y1' as different kind of symbol

    Redefinition of 'y1' as different kind of symbol 原因 解释:此次定义的y1变量与函数库中定义的y1重名了,所以编译错误,重定义了y1变量. 解决方法: ...

  8. git操作失误,提交代码因为网络问题没有成功,然后操作时候点错按钮导致代码全部没有了,也没用备份,如何解决

    最好的提交代码办法, 1.先创建一个空文件夹, 2.然后创建一个在线仓库 3. git remote add origin '仓库地址' 4.查看远程仓库 git remote remove orig ...

  9. 合并JSON文件

    下面是一段简单地代码 用来减少工作量合并代码 <!DOCTYPE html> <html lang="en"> <head> <meta ...

  10. (原创)【B4A】一步一步入门01:简介、开发环境搭建、HelloWorld

    一.前言 作者注:絮絮叨叨,可跳过不看. 一直有开发跨平台软件的需求.因为我的主力是C# ,所以当MAUI出现后,我欣喜若狂的开始学习研究.但是经历了两个月左右的时间,我弃坑了,我发现MAUI不是我能 ...