题解链接:https://blog.csdn.net/shiqi_614/article/details/8105149

用树形dp是超时的,,

/*
先求出每个点可以跑的最长距离dp[i][0|1]表示向下|上可以跑到最大距离
再用单调队列求最大连续天数
*/
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
#define maxn 1000005
#define ll long long
struct Edge{int to,nxt,w;}edge[maxn<<];
int dp[maxn][],head[maxn],tot,n,m;
void init(){
memset(head,-,sizeof head);
tot=;
} void addedge(int u,int v,int w){
edge[tot].to=v;edge[tot].w=w;
edge[tot].nxt=head[u];head[u]=tot++;
}
void dfs0(int u,int pre){
dp[u][]=;
for(int i=head[u];i!=-;i=edge[i].nxt){
int v=edge[i].to;
if(v!=pre){
dfs0(v,u);
dp[u][]=max(dp[u][],dp[v][]+edge[i].w);
}
}
}
void dfs1(int u,int pre){
long long Max=,Sec=,v1,v2;//u的大儿子下标,二儿子下标
for(int i=head[u];i!=-;i=edge[i].nxt){//这个循环处理出u的大儿子
int v=edge[i].to;
if(v==pre)continue;
int tmp=edge[i].w+dp[v][];
if(tmp>Max){//找到了更大的儿子树
Sec=Max,Max=tmp;
v2=v1,v1=v;
}
else if(tmp==Max || tmp>Sec)
Sec=tmp,v2=v;
}
//printf("%d %d\n",u,Max);
if(u!=-){//和u的上面进行比较
long long tmp=dp[u][],v=-;
if(tmp>Max){//找到了更大的儿子树
Sec=Max,Max=tmp;
v2=v1,v1=v;
}
else if(tmp==Max || tmp>Sec)
Sec=tmp,v2=v;
} for(int i=head[u];i!=-;i=edge[i].nxt){//这个循环求dp进行递归
int v=edge[i].to;
if(v==pre)continue;
if(v==v1)dp[v][]=Sec+edge[i].w;
else dp[v][]=Max+edge[i].w;
dfs1(v,u);
}
//printf("%d %d\n",u,Max);
}
int d[maxn],qmax[maxn],qmin[maxn];
void solve()
{
int ans=,i,j,front1,front2,rear1,rear2;
front1=rear1=;
front2=rear2=;
for(int i=;i<=n;i++)d[i]=max(dp[i][],dp[i][]);
for(i=,j=;j<=n;j++)
{
while(rear1>front1&&d[qmax[rear1-]]<=d[j]) rear1--;
qmax[rear1++]=j; while(rear2>front2&&d[qmin[rear2-]]>=d[j]) rear2--;
qmin[rear2++]=j; if(d[qmax[front1]]-d[qmin[front2]]>m)
{
ans=max(ans,j-i);
while(d[qmax[front1]]-d[qmin[front2]]>m)
{
i=min(qmax[front1],qmin[front2])+;
while(rear1>front1&&qmax[front1]<i) front1++;
while(rear2>front2&&qmin[front2]<i) front2++;
}
}
}
ans=max(ans,j-i);
printf("%d\n",ans);
} int main(){
while(cin>>n>>m){
init();
int u,v,w;
for(int v=;v<=n;v++){
cin>>u>>w;
addedge(u,v,w);
addedge(v,u,w);
} dfs0(,);//先求dp[i][0]
dfs1(,);//再求dp[i][1]
solve();
}
}

poj3162 树形dp|树的直径 + 双单调队列|线段树,好题啊的更多相关文章

  1. POJ 3162 Walking Race (树的直径,单调队列)

    题意:给定一棵带边权的n个节点的树,首先要求出每个点的最长路,然后写成序列d[1],d[2]...d[n],然后求满足 区间最大值-区间最小值<=k 的最大区间长度为多少? 思路: 分两步进行: ...

  2. [洛谷P1886]滑动窗口 (单调队列)(线段树)

    ---恢复内容开始--- 这是很好的一道题 题目描述: 现在有一堆数字共N个数字(N<=10^6),以及一个大小为k的窗口. 现在这个从左边开始向右滑动,每次滑动一个单位,求出每次滑动后窗口中的 ...

  3. POJ 2823 Sliding Window(单调队列 || 线段树)题解

    题意:求每个长度为k的数组的最大值和最小值 思路: 1.用线段树创建维护最大值和最小值,遍历询问,简单复习了一下...有点手生 2.单调队列: 可以看一下详解 单调队列顾名思义就是一个单调递增或者递减 ...

  4. [luoguP1440] 求m区间内的最小值(单调队列 || 线段树)

    传送门 这种水题没必要搞线段树了,单调队列就行啊. ——代码 #include <cstdio> ; , t = ; int a[MAXN], q[MAXN]; int main() { ...

  5. HDU 4122 Alice's mooncake shop (单调队列/线段树)

    传送门:http://acm.hdu.edu.cn/showproblem.php?pid=4122 题意:好难读懂,读懂了也好难描述,亲们就自己凑合看看题意把 题解:开始计算每个日期到2000/1/ ...

  6. newcoder H肥猪(单调队列 / 线段树)题解

    题意: 小B来到了一个异世界,成为了肥猪之王. 在这个异世界,共有n种肥猪,编号分别为1,...,n. 小B希望集齐这n种肥猪. 召集肥猪有两种方式: 1. 花费a[i]的金币召唤一只编号为i的肥猪. ...

  7. BZOJ 1012: [JSOI2008]最大数maxnumber 单调队列/线段树/树状数组/乱搞

    1012: [JSOI2008]最大数maxnumber Time Limit: 3 Sec  Memory Limit: 162 MBSubmit: 4750  Solved: 2145[Submi ...

  8. 【P1886】滑动窗口(单调队列→线段树→LCT)

    这个题很友好,我们可以分别进行简单难度,中等难度,恶心难度来做.然而智商没问题的话肯定是用单调队列来做... 板子题,直接裸的单调队列就能过. #include<iostream> #in ...

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

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

随机推荐

  1. Django REST framework 第七章 Schemas & client libraries

    模式是一个机器可读文档,描述可用的API端点,URL以及它们支持的操作. 模式对于自动生成文档是一个很有用的工具,也可以用来动态调用可以于API交互的客户端库. Core API 为了提供模式支持,R ...

  2. linux查看日志

    若想在linux下查询某个时间段的log,用sed命令示例如下: $ sed -n '/2017-11-11 11:00:00/,/2017-11-11 11:11:11/p'  error.log ...

  3. 为Oracle GoldenGate准备数据库

    了解如何为Oracle GoldenGate准备数据库,包括如何配置连接和日志记录,如何在数据库中启用Oracle GoldenGate,如何设置闪回查询以及如何管理服务器资源. 为集成进程配置连接 ...

  4. CF1097F Alex and a TV Show

    题目地址:CF1097F Alex and a TV Show bitset+莫比乌斯反演(个人第一道莫比乌斯反演题) 由于只关心出现次数的奇偶性,显然用bitset最合适 但我们并不直接在bitse ...

  5. HDOJ 1217 Arbitrage (最短路)

    题意:每两种货币之间都有不同的汇率  如果换回自己最后是赚的 输出Yes 否则是No 因为最多只有三十种货币 所以用Floyd是可行的 与一般的最短路板子不同的地方 汇率是要乘而不是加 如果乘上一个小 ...

  6. 【ARTS】01_19_左耳听风-20190318~20190324

    ARTS: Algrothm: leetcode算法题目 Review: 阅读并且点评一篇英文技术文章 Tip/Techni: 学习一个技术技巧 Share: 分享一篇有观点和思考的技术文章 Algo ...

  7. MySQL索引调优【转】

    一.关于查询计划 其实,关于所有的关系型数据库中,在运行T-SQL语句的时候,在查询器进行编译运行的同时,都会有着自己的内部的一个优化过程,而这优化之后的产物就是:执行计划. 在SQL SERVER中 ...

  8. shell文本左右对齐排版【转】

    文本左右对齐排版 有文本4.txt如下: 111111111111111111111 98912 张三 222222222222222222 150020 李四四 333333333333333333 ...

  9. linux 提高代码质量的工具

    很多IT公司对于软件开发都有严格的分工,这包括设计.测试.服务支持等等.但是,我一直都认为只有开发者才是真正对软件质量负责的人.没有好的软件设计,软件质量基本上是无从谈起.当然,要做到这一点是需要额外 ...

  10. Eclipse中三种设置编码格式的方法

    转自:https://blog.csdn.net/rainy_black_dog/article/details/52403735 很早以前听过一位老师说过:咱们中国人不管学习哪种编程语言,总会遇到乱 ...