题意:

  王国地图为 n 个节点的根树,首都为 1,

  m 个旅行家要去不同的终点旅游,他们分别有各自的预算,如果路上总费用超过预算就不去了

  给每条路定价, 让赚的钱最多

分析:

    DP[i][j]表示当从首都到城市i的路径花费为j时,以i为根的子树中的点作为目的城市的旅行者的最大花费.

  只需要考虑j值等于0或等于某位旅行者预算的情况,所以dp的状态数是O(NM)的.

  状态转移方程式:

  DP[i][j] = j* n(i,j) + ∑​max(DP[k][j​i]) (ji >= j)
    

    ( n(i,j)为以i作为目标城市且预算不小于j的旅行者数量,

      k 为 i 的所有子代节点

      ​max(DP[k][j​i]) 为节点k的所有ji >= j 的 DP[k][j​i] 的最大值 )

  上式max(DP[k, j​i]) (ji >= j) 可用 DP[i][j] = max(DP[i][j], DP[i][j+1]) 递推而得
则转移方程式为:

DP[i][j] = j* n(i,j) + DP[i][j].

  确定完每一点的最大花费总和后,两点的最大花费总和相减即为该边的定价

  注意起点的花费一定为 0 !

 #include <iostream>
#include <cstring>
#include <cstdio>
#include <vector>
#include <algorithm>
using namespace std;
#define LL long long
const int MAXN = ;
int t, n, m, s;
vector<int> mp[MAXN], id[MAXN];
LL dp[MAXN][MAXN];
LL v[MAXN];
int edge[MAXN][MAXN];
int bst[MAXN][MAXN];
LL ans[MAXN];
LL a[MAXN];
void DFS(int x,int fa)
{
for (int i = ; i < mp[x].size(); i++)
{
if (mp[x][i] != fa) DFS(mp[x][i], x);
}
for (int j = s-; j >= ; j--)
{
int t = ;
for (int i = ; i < id[x].size(); i++)
if (a[id[x][i]] >= v[j]) t++;
dp[x][j] += t*v[j]; //j* n(i,j)
for (int i = ; i < mp[x].size(); i++)
{
if (mp[x][i] == fa) continue;
int p = mp[x][i];
dp[x][j] += dp[p][j];
}
if (j == s- || dp[x][j+] <= dp[x][j])
{
bst[x][j] = j;
}
else
{
dp[x][j] = dp[x][j+];
bst[x][j] = bst[x][j+];
}
}
}
void DFS2(int x,int a,int fa)
{
for (int i = ; i < mp[x].size(); i++)
{
int e = mp[x][i];
if (e == fa) continue;
int b = bst[e][a];
ans[edge[x][e]] =v[b]- v[a];
DFS2(e,b,x);
}
}
int main()
{
scanf("%d", &t);
while (t--)
{
scanf("%d%d", &n, &m);
for (int i = ; i <= n; i++) mp[i].clear(), id[i].clear();
memset(dp,,sizeof(dp));
for (int i = ; i < n ;i++)
{
int u,v; scanf("%d%d", &u, &v);
mp[u].push_back(v);
mp[v].push_back(u);
edge[u][v] = edge[v][u] = i;
}
for (int i = ; i <= m; i++)
{
int u; scanf("%d%lld",&u, &a[i]);
v[i] = a[i];
id[u].push_back(i);
}
id[].clear();//起始点不计费!
v[] = ;
sort(v,v++m);
s = unique(v,v++m) - v;
DFS(,-);
DFS2(,,-);
printf("%lld\n",dp[][]);
for (int i = ; i < n-; i++)
printf("%lld ",ans[i]);
printf("%lld\n", ans[n-]);
}
}

HDU 5815 - Golden Week的更多相关文章

  1. HDU 3820 Golden Eggs (SAP | Dinic)

    Golden Eggs Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  2. HDU 4814 Golden Radio Base 小模拟

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=4814 题意:黄金比例切割点是,如今要求把一个10进制的的数转化成一个phi进制的数,而且不能出现'11'的 ...

  3. HDU 4814 Golden Radio Base 模拟

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4814 题目大意: 把一个正整数表示为φ进制, φ = (1+√5)/2 . 且已知: 1. φ + 1 ...

  4. HDU 4818 Golden Radio Base (2013长春现场赛B题)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4814 进制转换. 现场根据题目给的两个公式,不断更新!!! 胡搞就可以了. 现场3A,我艹,一次循环开 ...

  5. HDU 3820 Golden Eggs

    http://acm.hdu.edu.cn/showproblem.php?pid=3820 题意:n*m的格子,每个格子放金蛋或银蛋,每个格子的金蛋和银蛋都有一个对应的点权,如果有两个金蛋相连,则需 ...

  6. HDU 3820 Golden Eggs( 最小割 奇特建图)经典

    Golden Eggs Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Tota ...

  7. hdu 4814 Golden Radio Base

    详解见:http://blog.csdn.net/tri_integral/article/details/18666797 #include<cstdio> #include<cs ...

  8. Todo List

    Contest 11.13 2016ACM/ICPC亚洲区青岛站(5/13, solved 7/13) Training 11.06 2016年中国大学生程序设计竞赛(合肥)(solved 6/10) ...

  9. Golden Eggs HDU - 3820(最小割)

    Golden Eggs Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

随机推荐

  1. 选中CheckBoxList的值放到TextBox中,再次选中从textBox中删除

    当选中checkboxlist中的值,直接放到文本框中,在checkboxlist的SelectedIndexChanged事件下执行方法, //将选中的值放到文本框中                ...

  2. C#基本语句与C++区别

    条件语句必须为bool表达式 int a = 1; if(a) { ... } 在c++中可以,但c#报错 但 bool b = true;//不能写成b = 1了: if(b) { ... } 是可 ...

  3. C# 程序打包

    1:新建安装部署项目打开VS,点击新建项目,选择:其他项目类型->安装与部署->安装项目,然后点击确定.(详细见下图) 此主题相关图片如下: 2:开始打包2.1 确定即可进入项目文件夹:双 ...

  4. 关于毕设WiFi选型

    毕设做基于WiFi的家庭灯光影音控制,现在主要是WiFi模块上的选型,自己选了ESP8266. 一开始是看到了机智云的内容,想尝试机智云.但是目前没有母版,不知道怎么下手. 接下来就先尝试通过通用类型 ...

  5. hadoop之MapReduce WordCount分析

    MapReduce的设计思想 主要的思想是分而治之(divide and conquer),分治算法. 将一个大的问题切分成很多小的问题,然后在集群中的各个节点上执行,这既是Map过程.在Map过程结 ...

  6. android图像模糊技术

    今天我们来更深入了解一下Android开发上的模糊技术.我读过几篇有关的文章,也在StackOverFlow上看过一些相关教程的帖子,所以我想在这里总结一下学到的东西. 为什么学习这个模糊技术? 现在 ...

  7. python视频教程大全集下载

    python3英文视频教程(全87集) http://pan.baidu.com/s/1dDnGBvV Python从入门到精通视频(全60集)链接:http://pan.baidu.com/s/1e ...

  8. 在树莓派上安装leanote

    作者:冥王星 "noright0@163.com" 前言 宿舍有个树莓派2B,连接到电视机,安装OSMC系统,USB接口连接移动硬盘一块,平时用来BT下载和看电影.美剧. OSMC ...

  9. 我和小美的撸码日记--基于MVC+Jqgrid的.Net快速开发框架

    前言:以前的帐号没有发首页的权限,特此把这篇文章从另外一个博客移过来,这篇是<我和小美的撸码日记>的序 一转眼务农6年了,呆过大公司也去过小作坊,码农的人生除了抠腚还是抠腚.在所有呆过的公 ...

  10. 对163k地方门户网站系统QQ互联功能修改

    163k地方门户网站QQ互联申请时遇到的问题: "禁止开发商强制用户重新注册或绑定其他帐号" 原因是用户登录完QQ还需要注册帐号或者绑定原有帐号 163k地方门户网站的QQ互联登录 ...