考虑树是以1为中心的菊花图的情况,也即如何安排打怪兽的顺序

用二元组$(a,b)$来描述怪兽,则对于两个怪兽$(a_{1},b_{1})$和$(a_{2},b_{2})$,交换两者不会影响血量的变化量,而会改变初始血量的需求,具体即比较$\max(a_{1},a_{1}-b_{1}+a_{2})$和$\max(a_{2},a_{2}-b_{2}+a_{1})$

如果能证明传递性,那么以此进行排序即可

观察上述式子,可以得到以下信息:

1.$a\le b$的怪兽优于$a>b$的怪兽

2.对于$a\le b$的怪兽,$a$小的怪兽优于$a$大的怪兽

3.对于$a>b$的怪兽,$b$大的怪兽优于$b$小的怪兽

(代入均可证明)

进而上述信息足以比较,同时也具有传递性,即得证

回到原问题,有一个比较经典的套路:

考虑当前最优的位置,其父亲的怪兽被打死后一定会打其(注意怪兽只会被消除而不会增加),进而不妨将其与父亲合并(先打父亲再打其),合并方式参考之前

关于过程的维护,可以用一个并查集+set实现

时间复杂度为$o(n\log n)$,可以通过

 1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 100005
4 #define ll long long
5 struct Data{
6 ll a,b;
7 bool operator < (const Data &k)const{
8 if ((a<=b)!=(k.a<=k.b))return a<=b;
9 if (a<=b)return a<k.a;
10 return b>k.b;
11 }
12 }a[N];
13 vector<int>v[N];
14 set<pair<Data,int> >S;
15 int t,n,x,y,fa[N],f[N];
16 Data merge(Data x,Data y){
17 ll a=max(x.a,x.a-x.b+y.a);
18 return Data{a,x.b+y.b-x.a-y.a+a};
19 }
20 int find(int k){
21 if (k==f[k])return k;
22 return f[k]=find(f[k]);
23 }
24 void dfs(int k,int f){
25 fa[k]=f;
26 for(int i=0;i<v[k].size();i++)
27 if (v[k][i]!=f)dfs(v[k][i],k);
28 }
29 void merge(int x,int y){
30 x=find(x),y=find(y);
31 if (x!=1)S.erase(make_pair(a[x],x));
32 f[y]=x,a[x]=merge(a[x],a[y]);
33 if (x!=1)S.insert(make_pair(a[x],x));
34 }
35 int main(){
36 scanf("%d",&t);
37 while (t--){
38 scanf("%d",&n);
39 a[1]=Data{0,0},S.clear();
40 for(int i=1;i<=n;i++)v[i].clear();
41 for(int i=2;i<=n;i++){
42 scanf("%lld%lld",&a[i].a,&a[i].b);
43 S.insert(make_pair(a[i],i));
44 }
45 for(int i=1;i<n;i++){
46 scanf("%d%d",&x,&y);
47 v[x].push_back(y);
48 v[y].push_back(x);
49 }
50 dfs(1,0);
51 for(int i=1;i<=n;i++)f[i]=i;
52 for(int i=1;i<n;i++){
53 int x=(*S.begin()).second;
54 S.erase(S.begin());
55 merge(fa[x],x);
56 }
57 printf("%lld\n",a[1].a);
58 }
59 return 0;
60 }

[hdu6326]Monster Hunter的更多相关文章

  1. [HDU6326]Monster Hunter(贪心)

    用(a,b)表示一个点先失去a点HP,然后增加b点HP 首先容易证明忽略父亲条件下,任意两个点,先吃b大的最优 对于一个节点v和它的父节点u,若此时选v最优,那么就是吃到u时可以立即吃掉v, 于是可以 ...

  2. Day3-A-Problem H. Monster Hunter HDU6326

    Little Q is fighting against scary monsters in the game ``Monster Hunter''. The battlefield consists ...

  3. HDU暑假多校第三场H.Monster Hunter

    一.题意 给定一个树状地图,每个树节点上有一只怪物,打死一只怪物的过程中将会消耗A点HP,打死之后将会获得B点HP.因为树状结构,所以每只怪物必须先打死父节点的怪兽之后在打死子节点的怪物.现在,给定每 ...

  4. HDU 6326 Problem H Monster Hunter

    \(\mathtt{Problem H}\) \(\mathtt{Monster}\) \(\mathtt{Hunter}\) \(\mathcal{Description}\) 题目 给定一棵 \( ...

  5. 2020ICPC南京 M.Monster Hunter

    题目大意 一颗根为 \(1\) 的有 \((2≤≤2000)\) 个节点的树,每个节点有一个权值 \(ℎ_{} (1≤ℎ_{}≤10^9)\) ,能删除某个点的前提是其父亲节点已经被删除,并且删除一个 ...

  6. HDU 6326.Problem H. Monster Hunter-贪心(优先队列)+流水线排序+路径压缩、节点合并(并查集) (2018 Multi-University Training Contest 3 1008)

    6326.Problem H. Monster Hunter 题意就是打怪兽,给定一棵 n 个点的树,除 1 外每个点有一只怪兽,打败它需要先消耗 ai点 HP,再恢复 bi点 HP.求从 1 号点出 ...

  7. 2018 Multi-University Training Contest 3 - HDU Contest

    题解: solution Code: A. Ascending Rating #include<cstdio> const int N=10000010; int T,n,m,k,P,Q, ...

  8. 2018 HDU多校第三场赛后补题

    2018 HDU多校第三场赛后补题 从易到难来写吧,其中题意有些直接摘了Claris的,数据范围是就不标了. 如果需要可以去hdu题库里找.题号是6319 - 6331. L. Visual Cube ...

  9. 2018 Multi-University Training Contest 3 Solution

    A - Problem A. Ascending Rating 题意:给出n个数,给出区间长度m.对于每个区间,初始值的max为0,cnt为0.遇到一个a[i] > ans, 更新ans并且cn ...

随机推荐

  1. 2019 年 CNCF 中国云原生调查报告

    中国 72% 的受访者生产中使用 Kubernetes 在 CNCF,为更好地了解开源和云原生技术的使用,我们定期调查社区.这是第三次中国云原生调查,以中文进行,以便更深入地了解中国云原生技术采用的步 ...

  2. SpringBoot 后端接收前端传值的方法

    1.通过HttpServletRequest接收,适用于GET 和 POST请求方式       通过HttpServletRequest对象获取请求参数 @RestController @Reque ...

  3. 【UE4 C++】Input 输入事件绑定

    轴映射与动作映射 编辑器设置input+代码实现具体动作 void AMyCharacter::SetupPlayerInputComponent(UInputComponent* PlayerInp ...

  4. Gitflow branch与Docker image tag命名冲突怎么办?

    谷歌还是比必应要好用一点. 在前公司,我根据主流的git flow 给团队搭建了一套devops流程,运行在 docker & k8s上. 在现代devops流程中,一般推荐使用git分支名或 ...

  5. Noip模拟57 2021.9.20

    规律总结:联考必爆炸 T1 2A 没$A$掉的大水题,但是是真的不知道$000$前面的$00$也算先导$0$,以后要长记性,这种东西不能再错了 再打三遍: $000$前面的$00$也算先导$0$ $0 ...

  6. Azure File Storage(一)为本地机器配置网络磁盘

    一,引言 本地机器硬盘空间不够了怎么办?重要文件不想存储在本地硬盘怎么办?加外接移动硬盘:或者换大容量存储设备,都是解决方案.但是每次都得携带,还得考虑当前设备是否支持外接硬盘. 1,这个时候 Win ...

  7. stm32学习心得体会

    stm32作为现在嵌入式物联网单片机行业中经常要用多的技术,相信大家都有所接触,今天这篇就给大家详细的分析下有关于stm32的出口,还不是很清楚的朋友要注意看看了哦,在最后还会为大家分享有些关于stm ...

  8. 文件上传漏洞Bypass总结

    文件上传漏洞Bypass总结 前端JS验证文件类型: 上传后缀jpg,抓包改为php后缀 ======================================================= ...

  9. 转:Vivado IP报[Opt 31-67] 错误问题解决方法

    使用VIVADO编译代码时,其中一个IP报错,错误类似为 ImplementationOpt Design[Opt 31-67] Problem: A LUT2 cell in the design ...

  10. linux shell 函数返回值问题(超过255)

    最近再写一个shell测试的时候出现问题,函数返回值异常 用shell计算斐波那契数列数列,写了一个shell函数,然后调用的,验证的时候我只随便计算了几个数(10以内),确认结果是正确的就提交了,后 ...