[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]仙人掌的更多相关文章
- luogu P4129 [SHOI2006]仙人掌
题目描述 仙人掌图(cactus)是一种无向连通图,它的每条边最多只能出现在一个简单回路(simple cycle)里面.从直观上说,可以把仙人掌图理解为允许存在回路的树.但是仙人掌图和树之间有个本质 ...
- 2018.10.29 洛谷P4129 [SHOI2006]仙人掌(仙人掌+高精度)
传送门 显然求出每一个环的大小. Ans=∏i(siz[i]+1)Ans=\prod_i(siz[i]+1)Ans=∏i(siz[i]+1) 注意用高精度存答案. 代码: #include<b ...
- 洛谷 P4244 [SHOI2008]仙人掌图 II 解题报告
P4244 [SHOI2008]仙人掌图 II 题目背景 题目这个II是和SHOI2006的仙人掌图区分的,bzoj没有. 但是实际上还是和bzoj1023是一个题目的. 题目描述 如果某个无向连通图 ...
- bzoj1023: [SHOI2008]cactus仙人掌图
学习了一下圆方树. 圆方树是一种可以处理仙人掌的数据结构,具体见这里:http://immortalco.blog.uoj.ac/blog/1955 简单来讲它是这么做的:用tarjan找环,然后对每 ...
- 【BZOJ 1023】【SHOI 2008】cactus仙人掌图
良心的题解↓ http://z55250825.blog.163.com/blog/static/150230809201412793151890/ tarjan的时候如果是树边则做树形DP(遇到环就 ...
- 【BZOJ-1952】城市规划 [坑题] 仙人掌DP + 最大点权独立集(改)
1952: [Sdoi2010]城市规划 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 73 Solved: 23[Submit][Status][ ...
- 【BZOJ-4316】小C的独立集 仙人掌DP + 最大独立集
4316: 小C的独立集 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 57 Solved: 41[Submit][Status][Discuss] ...
- 仙人掌(cactus)
仙人掌(cactus) Time Limit:1000ms Memory Limit:64MB 题目描述 LYK 在冲刺清华集训(THUSC) !于是它开始研究仙人掌,它想来和你一起分享它最近研究的 ...
- 【bzoj1023】仙人掌图
[bzoj1023]仙人掌图 题意 给一棵仙人掌,求直径. \(n\leq 100000\) 分析 分析1:[Tarjan]+[环处理+单调队列优化线性dp]+[树形dp] 分开两种情况处理: ①环: ...
- hdu3594 强连通(仙人掌图)
题意:给定一张有向图,问是否是仙人掌图.仙人掌图的定义是,首先,这张图是一个强连通分量,其次所有边在且仅在一个环内. 首先,tarjan可以判强连通分量是否只有一个.然后对于所有边是否仅在一个环内,我 ...
随机推荐
- IDEA git配置
必备:安装Idea \ git配置git坏境:在环境变量中添加git安装包bin目录即可 1.去git官网申请一个账号 https://github.com/ 创建一个新的项目 2.在快速启动栏或者g ...
- variant conversion error for variable:v8
oracle 添加表数据报错:variant conversion error for variable:v8. 是数据类型不匹配.
- 【SQL】DML语句-SQL更新与删除:单表更新删除与连表更新删除语法
〇.概述 1.资料 sql连表删除:http://www.lanxinbase.com/?tag=sql%E8%BF%9E%E8%A1%A8%E5%88%A0%E9%99%A4 sql实现两表关联更新 ...
- python与数值计算环境安装
数值计算的编程的软件很多种,也见过一些编程绘图软件的对比. 利用Python进行数值计算,需要用到numpy(矩阵) ,scipy(公式符号), matplotlib(绘图)这些工具包. 1.Linu ...
- [python] Python二维码生成器qrcode库入门
Python二维码生成器qrcode库入门 qrcode是二维码生成的Python开源库,官方地址为python-qrcode.所有代码见:Python-Study-Notes. 文章目录 Pytho ...
- P8340 [AHOI2022] 山河重整
\(20pts\) 给 \(O(2^n)\) 枚举,\(60pts\) 是 \(O(n^2)\),先看看怎么做.计数题无非容斥和 \(dp\),不妨从 \(dp\) 入手.多项式复杂度的做法意味着无法 ...
- 《Kubernetes Operator 开发进阶》- 作者絮絮叨
目录 今天聊啥 本书读者 推荐序 推荐序1 - 邓洪超 推荐序2 - 任晶磊 推荐语 推荐语1 - 张磊 推荐语2 - 宋净超 推荐语3 - 王泽锋 推荐语4 - 周鹏飞 推荐语5 - 郑东旭 本书简 ...
- (二)elasticsearch 源码目录
在阅读源码之前,我们先来看看整个项目的结构:(同(一)elasticsearch 编译和启动,我们使用版本7.4.0作为示例) .ci,持续集成配置 .github, 里面有 PULL_REQUEST ...
- centos7.6安装本地yum源
centos7.6安装本地yum源 前言:文章内容可能会因环境不同而有所差异,所谓集思广益说不定灵感就来了呢; 文章初衷旨在交流学习.记录个人成长,如果能帮助到您,那就点个赞噢. 环境说明: 1.本实 ...
- BBS项目功能编写逻辑思路汇总
BBS项目功能编写逻辑思路汇总 一.BBS创数据表 二.BBS注册功能 三.BBS登录功能 四.BBS首页搭建 五.BBS修改密码 六.BBS个人站点 七.BBS文章详情 八.BBS导入模块 九.BB ...