[bzoj1791][ioi2008]Island 岛屿(基环树、树的直径)

bzoj luogu

题意可能会很绕

一句话:基环树的直径。

求直径:

对于环上每一个点记录其向它的子树最长路径为$dp_x$

之后记录环上边长前缀和$ns_i$

dp值为$max_{i,j}dp[i]+sum[i]+dp[j]-sum[j]$

$dp[j]-sum[j]$提出来进单调队列。

O(n)。

记得dfs改bfs。

#include<cstdio>
#include<algorithm>
using namespace std;
typedef long long lint;
const int N=1145141;
template<typename TP>inline void read(TP &kk){
TP ret=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){ret=ret*10+ch-'0';ch=getchar();}
kk=ret*f;
}
int n;
struct sumireko{int to,ne,w;}e[N*2];
int he[N],ecnt;
void addline(int f,int t,int w)
{
e[++ecnt].to=t;
e[ecnt].w=w;
e[ecnt].ne=he[f];
he[f]=ecnt;
}
bool vv[N],onr[N];
int rnd[N*2],hp,sp,nw[N*2];
lint ns[N*2]; int find(int x,int f)
{
if(vv[x]){sp=x;return 1;}
vv[x]=1;int tmp;
for(int i=he[x],t;i;i=e[i].ne)
{
t=e[i].to;
if(i==((f&1)?f+1:f-1)) continue;
if(tmp=find(t,i))
{
if(tmp==1)
{
rnd[++hp]=x;
onr[x]=1;
nw[hp]=e[i].w;
if(x!=sp) return 1;
}
return 2;
}
}
return 0;
}
lint dp[N],ans0,ans1;
int h,l;
int st[N];
bool use[N];
int fa[N];
void bfs(int u)
{
h = 1,l = 0;
st[++l] = u;
use[u]=1;
while(h<=l)
{
u = st[h++];
for(int j=he[u];j;j=e[j].ne)
{
int to = e[j].to;
if(use[to]||onr[to])continue;
use[to] = 1;
fa[to] = u;
st[++l] = to;
}
}
for(int i=l;i>=1;i--)
{
u = st[i];
for(int j=he[u];j;j=e[j].ne)
{
int to = e[j].to;
if(onr[to]||to==fa[u])continue;
lint tmp = dp[to]+e[j].w;
ans0 = max(ans0,dp[u]+tmp);
dp[u]=max(dp[u],tmp);
}
}
}
lint ans;
int qu[N*2],qh,qt;
void fuck(int xx)
{
ans0=ans1=0;
hp=0;
find(xx,0);
int x;
for(int i=1;i<=hp;i++)
{
x=rnd[i];
bfs(x);
nw[i+hp]=nw[i];
rnd[i+hp]=rnd[i];
}
for(int i=1;i<=2*hp;i++) ns[i]=ns[i-1]+nw[i];
qh=1,qt=0;
for(int i=1;i<2*hp;i++)
{
while(qh<qt&&qu[qh]+hp<=i) qh++;
if(qh<=qt)ans1=max(ans1,dp[rnd[i]]+ns[i]+dp[rnd[qu[qh]]]-ns[qu[qh]]);
while(qh<=qt&&dp[rnd[qu[qt]]]-ns[qu[qt]]<=dp[rnd[i]]-ns[i]) qt--;
qu[++qt]=i;
}
ans+=max(ans0,ans1);
hp=0;
} int xi,yi,wi;
signed main()
{
read(n);
for(int i=1;i<=n;i++)
{
read(xi),read(wi);
addline(i,xi,wi),addline(xi,i,wi);
}
for(int i=1;i<=n;i++) if(!use[i]) fuck(i);
printf("%lld\n",ans);
return 0;
}

[bzoj1791][ioi2008]Island 岛屿(基环树、树的直径)的更多相关文章

  1. BZOJ1791 [Ioi2008]Island 岛屿[基环树+单调队列优化DP]

    基环树直径裸题. 首先基环树直径只可能有两种形式:每棵基环树中的环上挂着的树的直径,或者是挂在环上的两个树的最大深度根之间的距离之和. 所以,先对每个连通块跑一遍,把环上的点找出来,然后对环上每个点跑 ...

  2. BZOJ1791[Ioi2008]Island 岛屿 ——基环森林直径和+单调队列优化DP+树形DP

    题目描述 你将要游览一个有N个岛屿的公园.从每一个岛i出发,只建造一座桥.桥的长度以Li表示.公园内总共有N座桥.尽管每座桥由一个岛连到另一个岛,但每座桥均可以双向行走.同时,每一对这样的岛屿,都有一 ...

  3. BZOJ1791: [Ioi2008]Island 岛屿

    BZOJ1791: [Ioi2008]Island 岛屿 Description 你将要游览一个有N个岛屿的公园. 从每一个岛i出发,只建造一座桥. 桥的长度以Li表示. 公园内总共有N座桥. 尽管每 ...

  4. bzoj1791: [Ioi2008]Island 岛屿 单调队列优化dp

    1791: [Ioi2008]Island 岛屿 Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 1826  Solved: 405[Submit][S ...

  5. bzoj千题计划114:bzoj1791: [Ioi2008]Island 岛屿

    http://www.lydsy.com/JudgeOnline/problem.php?id=1791 就是求所有基环树的直径之和 加手工栈 #include<cstdio> #incl ...

  6. bzoj1791[IOI2008]Island岛屿(基环树+DP)

    题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1791 题目大意:给你一棵n条边的基环树森林,要你求出所有基环树/树的直径之和.n< ...

  7. BZOJ 1791: [IOI2008]Island 岛屿 - 基环树

    传送门 题解 题意 = 找出无向基环树森林的每颗基环树的直径. 我们首先需要找到每颗基环树的环, 但是因为是无向图,用tarjan找环, 加个手工栈, 我也是看了dalao的博客才知道tarjan找无 ...

  8. [BZOJ1791][IOI2008]Island岛屿(环套树DP)

    同NOI2013快餐店(NOI出原题?),下面代码由于BZOJ栈空间过小会RE. 大致是对每个连通块找到环,在所有内向树做一遍DP,再在环上做两遍前缀和优化的DP. #include<cstdi ...

  9. P4381 [IOI2008]Island(基环树+单调队列优化dp)

    P4381 [IOI2008]Island 题意:求图中所有基环树的直径和 我们对每棵基环树分别计算答案. 首先我们先bfs找环(dfs易爆栈) 蓝后我们处理直径 直径不在环上,就在环上某点的子树上 ...

随机推荐

  1. erange.heetian.com 回显任意账号

      首先获取你想登录ID的REG标识符,例如合天课程专家  获取标识符ba84d3c3-a4a1-4cd2-a00d-2f5722ee86a2 一般用户前缀为REG,这个肯定是管理员之类的= =.. ...

  2. 猜猜我在哪里-linux查找命令

    文章目录 find findfs locate slocate which whereis pwd pwdx find: # 这是一个很强大的查找命令 findfs: # 依据卷标(LABEL)和UU ...

  3. CentOS7利用yum缓存搭建本地源

    CentOS7利用yum缓存搭建本地源 环境说明 [root@localhost ~]# cat /etc/redhat-release CentOS Linux release 7.6.1810 ( ...

  4. ICLR 2018 | Deep Gradient Compression: Reducing the Communication Bandwidth for Distributed Training

    为了降低大规模分布式训练时的通信开销,作者提出了一种名为深度梯度压缩(Deep Gradient Compression, DGC)的方法.DGC通过稀疏化技术,在每次迭代时只选择发送一部分比较&qu ...

  5. Spring MVC 是什么? 核心总结

    SpringMVC是一个基于Java的实现了MVC设计模式的请求驱动类型的轻量级Web框架,通过把Model,View,Controller分离,将web层进行职责解耦,把复杂的web应用分成逻辑清晰 ...

  6. pytest--pytest基本介绍

    pytest简介 pytest 是 python 的第三方单元测试框架,比自带的 unittest 更简洁和高 效,同时兼容 unittest 框架.它还有如下优点: 1.简单灵活,容易上手,文档丰富 ...

  7. 赶紧收藏!最好用的BI工具都在这了!

    1.bi厂商--思迈特软件Smartbi 广州思迈特软件有限公司成立于2011 年,以提升和挖掘企业客户的数据价值为使命,专注于商业智能与大数据分析软件产品与服务.思迈特软件是国家认定的"高 ...

  8. 【2021新】C#数字格式化字符串

    引用来源: https://www.cnblogs.com/flyingbread/archive/2007/01/18/620287.html https://www.cnblogs.com/117 ...

  9. Map<String,String>转Json转Base64

    Map<String,String> configMap = new HashMap<String,String>();System.out.println("JSO ...

  10. HTML学习如何布局

    <!DOCTYPE html><html><head> <meta charset="utf-8"> <title>菜鸟 ...