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\)重构树(具体是所有点按从小到大/从大到小的顺序,依次加入 ...
随机推荐
- 带你读AI论文丨LaneNet基于实体分割的端到端车道线检测
摘要:LaneNet是一种端到端的车道线检测方法,包含 LanNet + H-Net 两个网络模型. 本文分享自华为云社区<[论文解读]LaneNet基于实体分割的端到端车道线检测>,作者 ...
- WPF---数据绑定之ValidationRule数据校验综合Demo(七)
一.概述 我们利用ValidationRule以及ErrorTemplate来制作一个简单的表单验证. 二.Demo 核心思想:我们在ValidationRule中的Validate函数中进行验证, ...
- STM32+Air202+Air530+HXDZ-30102-ACC心率血氧GPS采集上传到阿里云
所有资料都在QQ群1121445919 主要功能 HXDZ-30102-ACC采集心率血氧数据 STM32通过串口将数据转发到air202模块 air202将数据上传到阿里云平台进行展示与处理 整合合 ...
- 前端~定位属性position(relative、absolute、fixed)的分析
前端~定位属性position(relative.absolute.fixed)的分析 1,简单了解: relative:移动自身时,参考自身的原来位置而移动,移动子元素(子元素设置了absolute ...
- element-ui 用 el-checkbox-group 做权限管理
template <el-checkbox-group v-model="menu_ide" v-for="(item,index) in menu_idss&qu ...
- 20210819 Emotional Flutter,Medium Counting,Huge Counting,字符消除2
考场 T1 一下想到了这题,将白块缩短 \(s\) 后维护类似的区间即可. T2 T3 俩计数,直接跳了. T4 的可行 \(t\) 集合相同相当与从 \(n\) 往前跳 kmp 数组,途径点相同,从 ...
- Python - 导入的位置
导入的是什么 导入是将 Python 的一些功能函数放到当前的脚本中使用 不导入的功能无法直接在当前脚本使用(除了 python 自带的内置函数) Python 有很多第三方功能,假设想要使用,都必须 ...
- poll?transport=longpoll&connection...烦人的请求c
1.问题描述: 最近使用miniui做了一个后台管理系统,打开浏览器调试时,总发现一堆无关的请求,结构大致是:poll?transport=longpoll&connection.....一直 ...
- k8s架构与组件详解
没有那么多花里胡哨,直接进行一个K8s架构与组件的学习. 一.K8s架构 k8s系统在设计是遵循c-s架构的,也就是我们图中apiserver与其余组件的交互.在生产中通常会有多个Master以实现K ...
- python模块--datetime
datatime.date类 构造器 返回值类型 说明 (year, month, day) date 类方法/属性 .max date datetime.date(9999, 12, 3 ...