codeforces#1249F. Maximum Weight Subset(树上dp)
时间:2019-10-23
本文章向大家介绍codeforces#1249F. Maximum Weight Subset(树上dp),主要包括codeforces#1249F. Maximum Weight Subset(树上dp)使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
题目链接:
http://codeforces.com/contest/1249/problem/F
题意:
一棵树的每个节点有个权值,选择一个节点集,使得任意点对的距离大于$k$
求最大节点集权值,节点集权值为节点集中节点权值和
数据范围:
$1\leq n \leq 200$
$1\leq k \leq 200$
分析:
定义$dp[v][i]$,代表在$v$这颗子树中,被选择的点最小深度恰好是$i$的最大答案
初始状态$dp[v][0]=a[v]$,这是没有子树的情况,然后再逐个添加子树
$ans=max(dp[n][i])$
AC代码:
#include<bits/stdc++.h> #define pii pair<int,int> #define ll long long using namespace std; const int maxn=200+7; int n,m,a[maxn],dp[maxn][maxn],tem[maxn];//dp[i][j]代表在i这个子树中,被选择的点的最小深度是j //ans=max(dp[n][j]) vector<int>ve[maxn]; void dfs(int x,int f){ dp[x][0]=a[x];//dp[x][0]比较特殊,不能通过子树转移 for(int i=0;i<ve[x].size();i++){ int v=ve[x][i]; if(v==f)continue; dfs(v,x); for(int j=0;j<=m;j++)tem[j]=dp[x][j]; for(int j=0;j<=m;j++)//枚举x子树中被用上的最小深度差为j for(int k=0;k<=m;k++)//枚举v子树中被用上的最小深度差为k if(j+k+1>=m)//深度相加合法,也就是可以这么选择 tem[min(j,k+1)]=max(tem[min(j,k+1)],dp[x][j]+dp[v][k]); for(int j=0;j<=m;j++)dp[x][j]=tem[j];//转移完再更新,保证是新子树和原来的子树们更新 } } int main(){ scanf("%d %d",&n,&m); m++; for(int i=1;i<=n;i++)scanf("%d",&a[i]); for(int i=1;i<=n-1;i++){ int a,b; scanf("%d %d",&a,&b); ve[a].push_back(b); ve[b].push_back(a); } dfs(1,-1); int ans=0; for(int i=0;i<=m;i++)ans=max(ans,dp[1][i]); printf("%d\n",ans); return 0; }
原文地址:https://www.cnblogs.com/carcar/p/11727059.html
- 2017广东工业大学程序设计竞赛初赛 题解&源码(A,水 B,数学 C,二分 D,枚举 E,dp F,思维题 G,字符串处理 H,枚举)
- python接口自动化7-参数关联
- 深度学习GPU环境Ubuntu16.04+GTX1080+CUDA9+cuDNN7+TensorFlow1.6环境配置
- python接口自动化8-参数化
- HDU 2037 今年暑假不AC(贪心,区间更新,板子题)
- “玲珑杯”ACM比赛 Round #13 题解&源码
- 回溯算法入门及经典案例剖析(初学者必备宝典)
- Selenium2+python自动化66-装饰器之运行失败截图
- 51Nod 1091 线段的重叠(贪心+区间相关,板子题)
- 51Nod 1016 水仙花数 V2(组合数学,枚举打表法)
- Selenium2+python自动化67-用例失败自动截图
- Codeforces Round #404 (Div. 2)(A.水,暴力,B,排序,贪心)
- hihoCoder #1053 : 居民迁移(贪心,二分搜索,google在线技术笔试模拟)
- php开发文章发布示例(正则表达式实例开发)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法