DP Intro - Tree DP Examples

 

 

 

因为上次比赛sb地把一道树形dp当费用流做了,受了点刺激,用一天时间稍微搞一下树形DP,今后再好好搞一下)

基于背包原理的树形DP

poj 1947 Rebuilding Roads

题意:给你一棵树,让你求最少剪掉多少条边可以剪出一棵点数为m的子树.

解法:dp[i][j]表示i节点得到j个节点的子树至少要剪多少边,对于每个节点a和它的孩子b,如果剪掉b,则dp(s)[a][j]=dp(s-1)[a][j], 如果保留<a,b>dp(s)[a][j]=min{dp(s-1)[a][j - k] + dp[b][k]}.初始条件为dp[a][1] = 0;

为了不产生后效性,需要由大到小枚举j的值。ans=min{dp[i][m] + 1,dp[root][m]}

 

[java] view plaincopy
print?
  1. void dfs(int a) {  
  2.         dp[a][1] = 0;  
  3.         for (int i = E[a]; i != -1; i = buf[i].ne) {  
  4.             int b = buf[i].be;  
  5.             dfs(b);  
  6.             num[a]+=num[b];  
  7.             for (int j =Math.min(m,num[a]); j > 0; j--) {  
  8.                 dp[a][j]++;  
  9.                 for (int k = 1; k <= j&&k<=num[b]; k++)  
  10.                     dp[a][j] = Math.min(dp[a][j], dp[a][j - k] + dp[b][k]);  
  11.             }  
  12.         }  
  13.     }  
void dfs(int a) {dp[a][1] = 0;for (int i = E[a]; i != -1; i = buf[i].ne) {int b = buf[i].be;dfs(b);num[a]+=num[b];for (int j =Math.min(m,num[a]); j > 0; j--) {dp[a][j]++;for (int k = 1; k <= j&&k<=num[b]; k++)dp[a][j] = Math.min(dp[a][j], dp[a][j - k] + dp[b][k]);}}}

 

 

poj 1155 TELE 

题意:其余点为转发站。客户端i愿支付的钱为pay[i],每条边需要的花费固定,问电台在保证不亏损的情况下,解法:dp[a][j] = Math.max(dp[a][j], dp[a][j - k] + dp[b][k]- buf[i].v);节点a给j个节点输送信号能赚多少钱 j k num有N座城堡,每座城堡都有一定的宝物,允许攻克M个城堡并获得里面的宝物。但有些城堡必须先攻克其他某一个特定的城堡才能攻克,问攻克M个城堡所获得的最多宝物的数量。

dp[a][j] = Math.max(dp[a][j], dp[a][k] + dp[b][j - k]);dp[a][j]代表从i开始攻克j的城堡的最大获利,初始化时dp[i][1]=i城堡内的宝贝数,dp[0][1]=0;dp[i][0]=0;ans=Max{dp[i][m],dp[0][m+1]};

------------------------------------------------------------------------------------------------------

 

Poj 2486 Apple Tree

题意:苹果树上有n个节点,每个节点数上有若干个苹果,问最多走m步后至多能吃多少个苹果。

解法:每个在路径上的节点有两种形态:一是以此节点为起点到达某点后不再返回,而是从此节点出发后返回再从其它孩子继续走。因此定义dp[a][j][0]为a节点第一种情况下走j步的最大获利dp[a][j][1]为a节点在第二种情况下走j步的最大获利。转移方程为:

 

dp[a][j][0]=Math.max(dp[a][j][0],dp[a][k][1]+dp[b][j-k-1][0]); dp[a][j][0]=Math.max(dp[a][j][0],dp[a][k][0]+dp[b][j-k-2][1]); dp[a][j][1]=Math.max(dp[a][j][1],dp[a][k][1]+dp[b][j-k-2][1])

 

初始化dp[i][0][1]=dp[i][0][0]=i节点的苹果数。ans=Max{0,dp[1][i][0]};

 

Poj 1655 balancing Act/poj 3107 Godfather

题意:一个节点的平衡因子定义为:删到此节点后形成的节点数最多的子树。求一棵树中平衡因子最大的节点。

解法,定义num[i]为i节点为根的子树的节点数max[i]为i节点孩子节点数的最大值,一个节点的平衡因子=ans= Math.max(ans, first + second);

 

Sgu149&&HDU2196 Computer

解法:一个点的最远路径或者是向下一直走或者是先走到父节点然后再从父节点开始走一条较长的路径。
     对于第一种情况由底向上更新求出每点的最长路径和次长路径即可;对于第二种情况,如果当前节点是父节点最长路径上的点,那么向上的最长路径=边权+父节点的次长路径,否则最长路径=边权+父节点的最长路径。得到向上的最长路径后更新最长路径和次长路径(如果更新了最长路径,需要更新一下原来向下最大孩子的状态,使它不是父节点最长路径上的点),从上向下dfs更新一下即可。

[java] view plaincopy
print?
  1. int dfs(int a) {  
  2.         int temp, f = 0;  
  3.         for (int i = E[a]; i != -1; i = buf[i].ne) {  
  4.             int b = buf[i].be;  
  5.             temp = dfs(b) + buf[i].v;  
  6.             if (temp > first[a]) {  
  7.                 second[a] = first[a];  
  8.                 first[a] = temp;  
  9.                 f = b;  
  10.             }  
  11.             else if(temp>second[a])  
  12.                 second[a]=temp;  
  13.         }  
  14.         fid[a] = f;  
  15.         isf[f] = true;  
  16.         return first[a];  
  17.     }  
  18.   
  19.     void work(int p, int a, int v) {  
  20.         int temp = -1;  
  21.         if (isf[a])  
  22.             temp = second[p] + v;  
  23.         else  
  24.             temp = first[p] + v;  
  25.         if (temp > first[a]) {  
  26.             second[a] = first[a];  
  27.             first[a] = temp;  
  28.             isf[fid[a]] = false;  
  29.         } else if (temp > second[a])  
  30.             second[a] = temp;  
  31.           
  32.         for (int i = E[a]; i != -1; i = buf[i].ne) {  
  33.             int b = buf[i].be;  
  34.             work(a, b, buf[i].v);  
  35.         }  
  36.     }  
int dfs(int a) {int temp, f = 0;for (int i = E[a]; i != -1; i = buf[i].ne) {int b = buf[i].be;temp = dfs(b) + buf[i].v;if (temp > first[a]) {second[a] = first[a];first[a] = temp;f = b;}else if(temp>second[a])second[a]=temp;}fid[a] = f;isf[f] = true;return first[a];}void work(int p, int a, int v) {int temp = -1;if (isf[a])temp = second[p] + v;elsetemp = first[p] + v;if (temp > first[a]) {second[a] = first[a];first[a] = temp;isf[fid[a]] = false;} else if (temp > second[a])second[a] = temp;for (int i = E[a]; i != -1; i = buf[i].ne) {int b = buf[i].be;work(a, b, buf[i].v);}}

转载于:https://www.cnblogs.com/avcs/p/6909961.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/572397.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

转换流/序列化/反序列化

转换流&#xff1a; 使用转换流可以在一定程度上避免乱码&#xff0c;还可以指定输入输出所使用的字符集 InputStreamReader&#xff1a;是从字节流到字符流的桥梁&#xff0c;父类是Reader OutputStreamWriter&#xff1a;是从字符流到字节流的桥梁&#xff0c;父类是Writer 转…

python+unittest框架整理(一点点学习前辈们的封装思路,一点点成长。。。)

预期框架整理目标&#xff1a; 1.单个用例维护在单个.py文件中可单个执行&#xff0c;也可批量生成组件批量执行 2.对定位参数&#xff0c;定位方法&#xff0c;业务功能脚本&#xff0c;用例脚本&#xff0c;用例批量执行脚本&#xff0c;常用常量进行分层独立&#xff0c;各自…

vs远程编译linux程序,使用Visual Studio 2015远程调试Linux程序

##安装 Visual Studio 2015安装时注意将跨平台移动开发->Visual C移动开发->Viaual C Android 开发的选项勾上##安装PUTTYVisual Studio依赖putty中的plink来连接Linux机器并发送命令##使用首先在Visual Studio中新建一个空项目这里是列表文本接下来将代码导入到这个空项…

都在说反射,反射到底是什么

概念&#xff1a; 什么是反射? 利用反射可以无视修饰符获取类里面所有的属性和方法对于任何对象&#xff0c;都能够调用它的方法和属性&#xff0c;这种动态获取信息以及动态调用对象方法的功能称为Java的反射 反射的应用场景? 常见的有&#xff1a; idea的智能提示、框架等…

LaunchScreen原理

会自动加载LaunchScreen是因为在Target当中,指定了Launch Screen file 它的底层实现其实把LaunchScreen上的东西,生成了一张图片,然后把这张图片设为程序的启动图片.可以进入沙盒当中查看,查看方法,找到应用程序根目录.获取方法: NSLog("%",NSHomeDirectory());打印出…

Mac - 苹果电脑mac系统释放硬盘空间方法汇总

硬盘空间是大家最头痛的一个问题&#xff0c;大家在硬盘空间变小的时候怎么腾空间的呢&#xff1f;下面为大家分享7个mac系统释放空间的高级方法&#xff0c;大家赶紧来收了&#xff01; mac系统释放硬盘空间方法&#xff1a; 方法一&#xff1a;删除Emacs——可以节省出60MB的…

XML语言

XML&#xff1a; XML是可扩展的标记语言 标记语言: 通过标签来描述数据的一门语言(标签有时我们也将其称之为元素) 可扩展&#xff1a;标签的名字是可以自定义的,XML文件是由很多标签组成的,而标签名是可以自定义的 xml学习网站https://www.w3school.com.cn/x.asp 作用&#xf…

xml中的Document和Attribute

1.Document 导入dom4j的步骤 去官网下载 zip 包。http://www.dom4j.org/ 在项目中创建一个文件夹&#xff1a;lib将dom4j-2.1.1.jar文件复制到 lib 文件夹在jar文件上点右键&#xff0c;选择 Add as Library -> 点击OK在类中导包使用 得到Document对象 步骤&#xff1a;…

XPath表达式

什么是XPath XPath&#xff1a;路径表达式 作用&#xff1a;在DOM解析XML时&#xff0c;通过XPath表达让解析更加简单 XPath表达式分类 绝对路径相对路径全文搜索属性查找 什么是Node对象 DOM树中的每个节点就是Node dom4j中与XPath相关的方法 注&#xff1a;使用XPat…

最详细MySQL的安装与介绍Windows

数据库的安装&#xff1a; 打开下载的mysql安装⽂件双击解压缩&#xff0c;运⾏“mysql-5.5.40-win32.msi”。 选择安装类型&#xff0c;有“Typical&#xff08;默认&#xff09;”、“Complete&#xff08;完全&#xff09;”、“Custom&#xff08;⽤户⾃定义&#xff09;”…

读懂基础机器学习算法

本篇内容主要是面向机器学习初学者&#xff0c;介绍常见的机器学习算法&#xff0c;当然&#xff0c;欢迎同行交流。 哲学要回答的基本问题是从哪里来、我是谁、到哪里去&#xff0c;寻找答案的过程或许可以借鉴机器学习的套路&#xff1a;组织数据->挖掘知识->预测未来。…

在c语言中有函数leapyear定义如下,职业教育概论——职业教育的发展历史超星尔雅答案题库...

职业职业展历有时候,文学造诣高的中国诗歌翻译者在用词华丽方面超过莎士比亚。有int型变量x&#xff0c;教育教育i&#xff0c;j&#xff0c;k&#xff0c;则表达式x(i5,j6,k7)的值为( )从数据表student中查询张姓的所有学生&#xff0c;概论正确的SQL语句是( )史超世界上第一个…

tomcat安装启动配置

服务器&#xff1a; 服务器的概念非常的广泛&#xff0c;它可以指代一台特殊的计算机&#xff08;相比普通计算机运行更快、负载更高、价格更贵&#xff09;&#xff0c;也可以指代用于部署网站的应用。我们这里说的服务器&#xff0c;其实是web服务器&#xff0c;或者应用服务…

JS在页面限制checkbox最大复选数

应该是挺简单的代码, 记录一下分享. 首先最直接的想法就是使用循环, 用局部变量记录已选的checkbox, 达到最大值就将余下的checkbox都禁止选择, 例如以下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" ""> <html xmlns"…

c语言 二维数组 文库,c语言二维数组练习题

c语言二维数组练习题 (3页)本资源提供全文预览&#xff0c;点击全文预览即可全文预览,如果喜欢文档就下载吧&#xff0c;查找使用更方便哦&#xff01;19.90 积分完成下列程序代码完成下列程序代码1、 将二维数组(5 行 5 列)的右上半部分置零。 即&#xff1a;1234510000678910…

android陀螺仪轨迹,陀螺仪轨迹法长距离管道测量精度实测分析

陀螺仪轨迹法长距离管道测量精度实测分析陀螺仪轨迹法用于非开挖管道的精准坐标与位置测量已被电力与燃气等行业逐步了解与接受&#xff0c;近两年不断被引入到城市地下管线探测及电力与燃气管道验收标准中。由于管道埋于地下往往不能眼见为实&#xff0c;作为一种新的测量方式…

Spring IOC详解与配置

Spring&#xff1a; 框架&#xff1a; 具有一定功能的半成品软件&#xff0c;基于框架会节省开发成本 框架作用&#xff1a; 提高开发效率、复用性、编写规范、节约维护成本、解耦底层实现原理 Spring&#xff1a; Spring是分层的JavaSE/EE应用full-stack轻量级开源框架Sprin…

android8.0的蓝牙版本,android o 新特性详解 安卓8.0蓝牙音频增强以及更加可爱的表情包...

android 8.0什么时候推出&#xff1f;有哪些新特色&#xff1f;很多安卓用户非常想知道答案吧&#xff01;不用着急&#xff0c;下面是大麦子小编整理出来的安卓8.0新特性详解&#xff0c;希望可以帮到大家。有媒体近日曝光了有关谷歌Pixel XL 2手机会首发Android 8.0系统。现在…

DOM初级篇

DOM是什么、作用、与javascript&#xff1f; DOM是对HTML文档的访问和操作&#xff0c;对文档的增删改查。 DOM相当于是javascript一个类&#xff0c;这个类中提供了多种操作HTML的方法&#xff0c;也可以说DOM是依附在JavaScript上进行操作的。 一、标签的查找命令&#xff1b…

vs2019开发android应用,VS 2019开发APP(一)界面和代码

1.界面在Resources>layout>目录下的*.xml文件就是界面文件2.关联界面接下来&#xff0c;通过将支持代码插入到 MainActivity 类中来添加代码以关联用户界面。在 MainActivity 类中找到 OnCreate 方法&#xff0c;在其中添加关联按钮代码如下&#xff1a;protected overri…