AT4144-[ARC098D]Donation【Kruskal重构树,dp】
正题
题目链接:https://www.luogu.com.cn/problem/AT4144
题目大意
\(n\)个点\(m\)条边的一张无向联通图,每个点有两个值\(a_i,b_i\)。表示经过该点时需要拥有\(a_i\)元,该点需要捐献\(b_i\)元。
任意起点,询问开始时至少多少钱才能捐献完所有点。
解题思路
\(WC2021\)和\(XJ\)杂题都讲过倒过来跑贪心的做法,不过我不知道怎么确定起点就爬了
首先定义\(c_i=max\{a_i-b_i,0\}\),因为\(a_i\leq b_i\)没有意义,所以这个\(c_i\)是有意义的部分。
图的话好像很麻烦,先搞一个\(Kruskal\)重构树,不过这个是点权的,方法差不多,从小到大枚举点权就好了。
然后考虑一下我们的策略,肯定是走到一个点会顺便走完整个子树会更优。
所以设\(f_x\)表示走完子树\(x\)需要的权值,考虑如何转移,我们肯定是先从前面若干个子树走完捐献一遍后再捐献点\(x\),然后走向最后一个子树。
以我们可以枚举最后一个子树\(y\),然后转移方程就是
\]
(这里\(s_x\)表示子树\(x\)的权值和)
这个转移的前面很好懂,就是捐赠其他子树,因为\(c_x\)一定大于它子树里的,所以不用考虑里面的\(c\)。之后后面那个就是两种限制取一个最大值。
时间复杂度\(O(n\log n)\)(排序复杂度)
code
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
#define ll long long
using namespace std;
const ll N=1e5+10;
struct node{
ll to,next;
}a[N];
ll n,m,tot,ls[N],fa[N],l[N],w[N],p[N],f[N];
vector<ll> G[N];bool v[N];
bool cmp(ll x,ll y)
{return l[x]<l[y];}
ll find(ll x)
{return (fa[x]==x)?x:(fa[x]=find(fa[x]));}
void addl(ll x,ll y){
a[++tot].to=y;
a[tot].next=ls[x];
ls[x]=tot;return;
}
void dp(ll x){
if(!ls[x])f[x]=l[x]+w[x];
else f[x]=1e18;
for(ll i=ls[x];i;i=a[i].next){
ll y=a[i].to;dp(y);
f[x]=min(f[x],w[x]-w[y]+max(l[x],f[y]));
}
return;
}
signed main()
{
scanf("%lld%lld",&n,&m);
for(ll i=1;i<=n;i++){
scanf("%lld%lld",&l[i],&w[i]);
l[i]=max(l[i]-w[i],0ll);p[i]=i;
}
for(ll i=1;i<=m;i++){
ll x,y;
scanf("%lld%lld",&x,&y);
G[x].push_back(y);
G[y].push_back(x);
}
sort(p+1,p+1+n,cmp);
for(ll i=1;i<=n;i++)fa[i]=i;
for(ll k=1;k<=n;k++){
ll x=p[k];
for(ll i=0;i<G[x].size();i++){
ll y=G[x][i];
if(!v[y])continue;
ll Fa=find(y),Fb=find(x);
if(Fa==Fb)continue;
fa[Fa]=Fb;w[Fb]+=w[Fa];
addl(Fb,Fa);
}
v[x]=1;
}
dp(p[n]);
printf("%lld\n",f[p[n]]);
return 0;
}
AT4144-[ARC098D]Donation【Kruskal重构树,dp】的更多相关文章
- [bzoj 3732] Network (Kruskal重构树)
kruskal重构树 Description 给你N个点的无向图 (1 <= N <= 15,000),记为:1-N. 图中有M条边 (1 <= M <= 30,000) ,第 ...
- 【BZOJ 3732】 Network Kruskal重构树+倍增LCA
Kruskal重构树裸题, Sunshine互测的A题就是Kruskal重构树,我通过互测了解到了这个神奇的东西... 理解起来应该没什么难度吧,但是我的Peaks连WA,,, 省选估计要滚粗了TwT ...
- 【BZOJ-3545&3551】Peaks&加强版 Kruskal重构树 + 主席树 + DFS序 + 倍增
3545: [ONTAK2010]Peaks Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1202 Solved: 321[Submit][Sta ...
- BZOJ 3551: [ONTAK2010]Peaks加强版 [Kruskal重构树 dfs序 主席树]
3551: [ONTAK2010]Peaks加强版 题意:带权图,多组询问与一个点通过边权\(\le lim\)的边连通的点中点权k大值,强制在线 PoPoQQQ大爷题解传送门 说一下感受: 容易发现 ...
- bzoj 3551 kruskal重构树dfs序上的主席树
强制在线 kruskal重构树,每两点间的最大边权即为其lca的点权. 倍增找,dfs序对应区间搞主席树 #include<cstdio> #include<cstring> ...
- kruskal重构树学习笔记
\(kruskal\) 重构树学习笔记 前言 \(8102IONCC\) 中考到了,本蒟蒻不会,所以学一下. 前置知识 \(kruskal\) 求最小(大)生成树,树上求 \(lca\). 算法详 ...
- Kruskal重构树入门
这个知识点好像咕咕咕了好长了..趁还没退役赶紧补一下吧.. 讲的非常简略,十分抱歉.. 前置知识 Kruskal算法 一定的数据结构基础(如主席树) Kruskal重构树 直接bb好像不是很好讲,那就 ...
- UOJ#407. 【IOI2018】狼人 Kruskal,kruskal重构树,主席树
原文链接https://www.cnblogs.com/zhouzhendong/p/UOJ407.html 题解 套路啊. 先按照两个节点顺序各搞一个kruskal重构树,然后问题转化成两棵krus ...
- LOJ.2865.[IOI2018]狼人(Kruskal重构树 主席树)
LOJ 洛谷 这题不就是Peaks(加强版)或者归程么..这算是\(IOI2018\)撞上\(NOI2018\)的题了? \(Kruskal\)重构树(具体是所有点按从小到大/从大到小的顺序,依次加入 ...
随机推荐
- 0x800b010a 证书
无论是装微软的什么应用,只要报这个错误,下载这个证书: http://download.microsoft.com/download/2/4/8/248D8A62-FCCD-475C-85E7-6ED ...
- mybatis学习日志一
Mybatis 介绍 MyBatis 是支持 普通 SQL 查询 , 存储过程 和 高级映射 的优秀持久层框架.MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以 及对结果集的检索封装 ...
- 连接共享打印机失败错误代码0x80070035
局域网内共享打印机非常方便,但是在连接中经常遇到问题,其中出现错误代码0x80070035的概率非常之高! 1.必须确保有关打印功能的相关服务都处于自动启动状态,重点检查TCP/IP NetBIOS ...
- servlet通过响应头Content-Disposition实现文件下载效果
package day08; import java.io.File; import java.io.FileInputStream; import java.io.IOException; impo ...
- 对集合使用Comparator
1 import java.util.Comparator; 2 import java.util.PriorityQueue; 3 4 /** 5 * 对集合使用Comparator,不改变对象的自 ...
- 刷题-力扣-50. Pow(x, n)
50. Pow(x, n) 题目链接 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/powx-n/ 著作权归领扣网络所有.商业转载请联系官方授 ...
- Java基础和常用框架的面试题
前言 最近学校也催着找工作了,于是刷了一些面试题,学习了几篇大佬优秀的博客,总结了一些自认为重要的知识点:听不少职场前辈说,对于应届毕业生,面试时只要能说到核心重要的点,围绕这个点说一些自己的看法,面 ...
- vue ele table表格 设置只能勾选一个
table 更改属性设置: <el-table ref="multipleTable" :data="tableData" tooltip-effect= ...
- vue 嵌入倒计时组件( 亲测可用 )
由于花费了我不少时间才找到的组件,所以记录一下,后面方便自己好找一些,也算是分享出来给各位前端一起用. npm 下载npm install vue2-flip-countdown --save tem ...
- Shell脚本一键部署——源码编译安装MySQL及自动补全工具
Shell脚本一键部署--源码编译安装MySQL及自动补全工具 编译安装MySQL 1.软件包 Mysql安装包 将安装包拖至/opt目录下,编辑一个脚本文件,将以下内容复制进去,然后source或者 ...