题面

树形\(\text{DP}\)与贪心的结合。

首先考虑树形\(\text{DP}\)。

设\(dp_i\)表示从\(i\)出发,访问\(i\)的子树,并且最后回到\(i\)能获得的最大收益。

转移时优先挑选\(dp_j\)较大的\(j\)访问,直到用尽次数为止。

然后考虑解的唯一性。

我们发现这个东西是可以传递的,即:一个节点的子节点答案不唯一,那么这个节点的答案也不唯一。

如果当前访问到的节点与下一个要访问的节点\(dp\)值相同(可以与下一个节点交换访问顺序),或者它的\(dp\)值为\(0\)(可以不访问),那么这个节点的答案就不唯一。

如果按照我的写法就要注意一个问题:在递归时记录儿子个数的变量需要在第一轮遍历后清空,并且记录儿子。当然可以使用优先队列解决这个问题。

代码也很好写:

#include <bits/stdc++.h>
#define DEBUG fprintf(stderr, "Passing [%s] line %d\n", __FUNCTION__, __LINE__)
#define itn int
#define gI gi using namespace std; inline int gi()
{
int f = 1, x = 0; char c = getchar();
while (c < '0' || c > '9') {if (c == '-') f = -1; c = getchar();}
while (c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return f * x;
} const int maxn = 100003; int n, m, tot, head[maxn], ver[maxn * 2], nxt[maxn * 2];
int sy[maxn], sj[maxn], son[maxn], sz, cnt;
int wy[maxn];
long long dp[maxn]; inline void add(int u, int v)
{
ver[++tot] = v, nxt[tot] = head[u], head[u] = tot;
} inline bool cmp(int x, int y) {return dp[x] > dp[y];} void dfs(int u, int f)
{
dp[u] = 1ll * sy[u];
for (int i = head[u]; i; i = nxt[i])
{
int v = ver[i];
if (v == f) continue;
dfs(v, u);
}
cnt = 0; //注意要在这里清零
for (int i = head[u]; i; i = nxt[i])
{
int v = ver[i];
if (v == f) continue;
son[++cnt] = v;
}
sort(son + 1, son + 1 + cnt, cmp);
int now = 0;
while (now < min(cnt, sj[u] - 1) && dp[son[now + 1]] >= 0)
dp[u] += dp[son[++now]], wy[u] |= wy[son[now]];
if ((now > 0 && now < cnt && dp[son[now]] == dp[son[now + 1]]) || (now > 0 && dp[son[now]] == 0))
wy[u] = 1;
} int main()
{
//freopen(".in", "r", stdin);
//freopen(".out", "w", stdout);
n = gi();
for (int i = 2; i <= n; i+=1) sy[i] = gi();
for (int i = 2; i <= n; i+=1) sj[i] = gi();
for (int i = 1; i < n; i+=1) {int u = gi(), v = gi(); add(u, v), add(v, u);}
sj[1] = n + 1;
dfs(1, 0);
printf("%lld\n", dp[1]);
if (wy[1]) puts("solution is not unique");
else puts("solution is unique");
return 0;
}

最新文章

  1. iOS系列 基础篇 07 Action动作和输出口
  2. 《JavaScript高级程序设计(第3版)》笔记-第1章-JavaScript 简介
  3. Oracle SQL的硬解析和软解析
  4. 【腾讯Bugly干货分享】React移动web极致优化
  5. struts2的核心和工作原理
  6. C# 十进制与十六进制互转
  7. 实用Linux命令,不求最全但求实用-------磁盘使用情况du,df
  8. UVa 11389 (贪心) The Bus Driver Problem
  9. 查看Linux相关信息
  10. html form表单提交数据并后台获取
  11. Windows 下 Python easy_install 的安装
  12. 灰色关联度Matlab代码
  13. createjs绘制扇形的方法
  14. UNIX网络编程——常用服务器模型总结
  15. THUSCH 2017 大魔法师(矩阵乘法+线段树)
  16. 7种清除浮动 (感觉br最好用然而我用的还是overflow)
  17. Hadamard product
  18. 二叉树系列 - [LeetCode] Symmetric Tree 判断二叉树是否对称,递归和非递归实现
  19. JVM 类加载全过程
  20. 关于socket的疑问

热门文章

  1. 二维数组的生成-new的使用
  2. ArcGIS Runtime SDK for Android中SimpleFillSymbol.Style样式
  3. modules模块
  4. P1339 [USACO09OCT]热浪Heat Wave(SPFA)
  5. spring中JdbcTemplate使用
  6. 输出《Harry Potter and the Sorcerer&#39;s Stone》文本中的前N个最长用的英文单词及其数量
  7. [PAT] A1017 Queueing at Bank
  8. CF1254E Send Tree to Charlie
  9. 数据结构与算法之比较排序【Java】
  10. Docker最全教程——从理论到实战(十五)