hdu2196树形dp
有一棵树,找每个节点所能到达的最远距离是多少
dis[u][0]正向最大距离 dis[u][1]正向次大距离 dis[u][2]反向最大距离
先一边dfs求出每个节点的正向最大距离(就是向下)和次向最大距离,以及longest记录下当前节点的正向最大距离路径的子节点(为了第二遍dfs,判断这一条路是不是正向最大距离)
再进行第二遍dfs,v是u 的子节点,如果v在u的正向最大距离路径里(即longest[u]=v)那么v的最大反向距离就是max(u的最大反向距离,u的正向次大距离)+w【u】【v】
如果v不在u 的正向最大距离路径里,那么v的最大反向距离就是max(u的最大反向距离,u的正向最大距离)+w【u】【v】
#include<map>
#include<set>
#include<cmath>
#include<queue>
#include<stack>
#include<vector>
#include<cstdio>
#include<cassert>
#include<iomanip>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define pi acos(-1)
#define ll long long
#define mod 1000000007
#define ls l,m,rt<<1
#define rs m+1,r,rt<<1|1
#pragma comment(linker, "/STACK:1024000000,1024000000") using namespace std; const double g=10.0,eps=1e-;
const int N=+,maxn=+,inf=0x3f3f3f; struct edge{
int to,Next,w;
}e[N*];
int cnt,Head[N];
int longest[N],dis[N][];//0正向最大距离,1正向次大距离,2反向最大距离
void add(int u,int v,int w)
{
e[cnt].to=v;
e[cnt].w=w;
e[cnt].Next=Head[u];
Head[u]=cnt++;
}
int dfs1(int u,int fa)//返回u的正向最大距离,fa是u的父节点
{
if(dis[u][]>)return dis[u][];
dis[u][]=dis[u][]=dis[u][]=longest[u]=;
for(int i=Head[u];~i;i=e[i].Next)
{
int v=e[i].to;
if(v==fa)continue;
if(dis[u][]<dfs1(v,u)+e[i].w)//v是u的最大距离中的一个子节点
{
longest[u]=v;
dis[u][]=max(dis[u][],dis[u][]);//此时dis[u][0]就是一个可能的次大节点了
dis[u][]=dfs1(v,u)+e[i].w;
}
else if(dis[u][]<dfs1(v,u)+e[i].w)
dis[u][]=max(dis[u][],dfs1(v,u)+e[i].w);
}
return dis[u][];
}
int dfs2(int u,int fa)
{
for(int i=Head[u];~i;i=e[i].Next)
{
int v=e[i].to;
if(v==fa)continue;
if(longest[u]==v)dis[v][]=max(dis[u][],dis[u][])+e[i].w;
else dis[v][]=max(dis[u][],dis[u][])+e[i].w;
dfs2(v,u);
}
}
int main()
{
ios::sync_with_stdio(false);
cin.tie();
int n;
while(cin>>n){
cnt=;
memset(Head,-,sizeof Head);
memset(dis,-,sizeof dis);
memset(longest,-,sizeof longest);
for(int i=;i<=n;i++)
{
int v,w;
cin>>v>>w;
add(i,v,w);
add(v,i,w);
}
dfs1(,-);
dfs2(,-);
for(int i=;i<=n;i++)
cout<<max(dis[i][],dis[i][])<<endl;
}
return ;
}
/*
longest[i]=j代表i在子树中的最大距离经过了j节点
*/
树形dp
hdu2196树形dp的更多相关文章
- hdu2196 树形dp经典|树的直径
		/* 两种做法 1.求出树直径v1,v2,那么有一个性质:任取一点u,树上到u距离最远的点必定是v1或v2 那么可以一次dfs求树v1 第二次求dis1[],求出所有点到v1的距离,同时求出v2 第三 ... 
- Computer(HDU2196+树形dp+树的直径)
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2196 题目: 题意:有n台电脑,每台电脑连接其他电脑,第i行(包括第一行的n)连接u,长度为w,问你每 ... 
- hdu2196 树形dp
		题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=2196 Problem Description A school bought the fi ... 
- hdu-2196 树形dp   求一个树中所有节点能到达的最远距离f[i] (其实也不难嘛!)
		#include <bits/stdc++.h> using namespace std; ; struct T { int to; int w; }; vector < vecto ... 
- 【树形dp小练】HDU1520 HDU2196 HDU1561 HDU3534
		[树形dp]就是在树上做的一些dp之类的递推,由于一般须要递归处理.因此平庸情况的处理可能须要理清思路.昨晚開始切了4题,作为入门训练.题目都很easy.可是似乎做起来都还口以- hdu1520 An ... 
- HDU2196 Computer(树形DP)
		和LightOJ1257一样,之前我用了树分治写了.其实原来这题是道经典的树形DP,感觉这个DP不简单.. dp[0][u]表示以u为根的子树中的结点与u的最远距离 dp[1][u]表示以u为根的子树 ... 
- HDU5834 Magic boy Bi Luo with his excited tree(树形DP)
		题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5834 Description Bi Luo is a magic boy, he also ... 
- Codeforces 543D Road Improvement(树形DP + 乘法逆元)
		题目大概说给一棵树,树的边一开始都是损坏的,要修复一些边,修复完后要满足各个点到根的路径上最多只有一条坏的边,现在以各个点为根分别求出修复边的方案数,其结果模1000000007. 不难联想到这题和H ... 
- POJ3162 Walking Race(树形DP+尺取法+单调队列)
		题目大概是给一棵n个结点边带权的树,记结点i到其他结点最远距离为d[i],问d数组构成的这个序列中满足其中最大值与最小值的差不超过m的连续子序列最长是多长. 各个结点到其他结点的最远距离可以用树形DP ... 
随机推荐
- Lua4.0中getn陷阱
			Lua4.0中getn潜规则 • 使用t[n] = nil方式删除元素会导致意外结果 t = {, , , , , , , , , }; t[] = nil; t = {, , , , , , , , ... 
- flask—信号(blinker)
			Flask框架中的信号基于blinker,主要是让开发者在flask请求过程中定制一些用户行为. 安装blinker pip3 install blinker 1.内置信号 request_start ... 
- Python(异常处理)
			一 错误和异常 程序中难免出现错误,而错误分成两种 1.语法错误(这种错误,根本过不了python解释器的语法检测,必须在程序执行前就改正) 2.逻辑错误(逻辑错误) 什么是异常 异常就是程序运行时发 ... 
- 在debian9上安装mongodb
			MongoDB是一个免费的开源NoSQL文档数据库,在现代Web应用程序中常用.在本教程中,您将安装MongoDB,管理其服务,并可选择启用远程访问.要遵循这个...... 介绍 MongoDB是一个 ... 
- git安装教程(windows安装)
			git下载地址 https://git-scm.com/download/win 选择安装的组件,推荐全选 Additional icons 附加图标  On the Desktop 在桌面上 Wi ... 
- Linux系统——特殊符号、通配符及正则表达式
			特殊符号 | 管道符号,将管道符左边的命令的执行结果以字符串的形式通过 管道符传送到管道符右边命令末尾,作为管道符右边命令的执行 范围 > 输出重定向 >> 追加输出重定向 < ... 
- v9上传图片/附件失败出现undefined的解决方法之一
			把phpcms\modules\attachment\attachments.php中将 if(empty($this->userid)){改成 ... 
- linux上使用wget下载文件
			首次安装的centos操作系统是没有安装wget的,所以首先需要先安装wget,然后才能使用wget下载文件. 1.第一步,保证centos能正常连网.使用命令 :yum -y install wg ... 
- bind函数的作用
			面向连接的网络应用程序分为客户端和服务器端.服务器端的执行流程一般为4步,客户端程序相对简单,一般需要两个步骤. 服务器端执行流程4步如下: (1)调用socket函数,建立一个套接字,该套接字用于接 ... 
- SiteMesh使用(2.4.2)
			SiteMesh是一个网页布局和修饰的框架.我理解的是在一个母版页上引入页面各个位置的信息,从而拼接成一个页面展示出来.它定义了一个过滤器,把页面统一加上头部和底部. 我的项目是在springmvc中 ... 
