\(\mathcal{Description}\)

  Link.

  给定 \(n\) 个区间,第 \(i\) 个为 \([l_i,r_i]\),有权值 \(w_i\)。设一无向图 \(G=(V=\{1,2,\dots,n\},E)\),\((u,v)\in E\Leftrightarrow [l_u,r_u]\cap[l_v,r_v]\not=\varnothing\),求删除若干区间使得 \(G\) 无环的被删除区间权值和的最小值。

  \(n\le2.5\times10^5\)。

\(\mathcal{Solution}\)

  不要学了 DP 就只想 DP,优化不来麻烦推翻重来。

  首先 \(G\) 的合法条件等价于不存在三区间交于一点,这是一个经典费用流流模型,建图方法略。

  当然直接 Dinic 啥的直接挂掉,考虑到只需要增广两次,可以使用势能 Dijkstra + EK 算法求最小费用最大流。概括上来说,令 \(u\) 的势能 \(h_u\) 为累加的 \(d_u\) 之和,使得此时图上 \(w(u,v)+h_u-h_v\) 非负,就能跑 Dijkstra 了。本题只用增广两次,所以在初始 DAG 上求出 \(h\) 后甚至不必更新。

  具体讲解:OneInDark %%%.

\(\mathcal{Code}\)

/*~Rainybunny~*/

#include <queue>
#include <cstdio>
#include <iostream> #define rep( i, l, r ) for ( int i = l, rep##i = r; i <= rep##i; ++i )
#define per( i, r, l ) for ( int i = r, per##i = l; i >= per##i; --i ) typedef long long LL;
typedef std::pair<LL, int> PLI;
#define fi first
#define se second template<typename Tp>
inline Tp tmin( const Tp& a, const Tp& b ) { return a < b ? a : b; } const int MAXN = 2.5e5, MAXV = 5e5;
const LL LINF = 1ll << 60;
int n, ecnt = 1, mxp, head[MAXV + 5];
struct Edge { int to, flw; LL cst; int nxt; } graph[( MAXV + MAXN ) * 2 + 5];
LL hgt[MAXV + 5], dis[MAXV + 5];
int pre[MAXV + 5], flw[MAXV + 5]; inline void link( const int s, const int t, const int f, const LL c ) {
graph[++ecnt] = { t, f, c, head[s] }, head[s] = ecnt;
graph[++ecnt] = { s, 0, -c, head[t] }, head[t] = ecnt;
} inline void getHeight() {
hgt[0] = 0;
rep ( u, 0, mxp - 1 ) {
for ( int i = head[u]; i; i = graph[i].nxt ) if ( graph[i].flw ) {
hgt[graph[i].to] = tmin( hgt[graph[i].to], hgt[u] + graph[i].cst );
}
}
} inline bool dijkstra() {
static bool vis[MAXV + 5];
static std::priority_queue<PLI, std::vector<PLI>, std::greater<PLI> > heap;
rep ( i, 0, mxp ) pre[i] = flw[i] = 0, dis[i] = LINF, vis[i] = false; heap.push( { dis[0] = 0, 0 } ), flw[0] = 2;
while ( !heap.empty() ) {
PLI p( heap.top() ); heap.pop();
if ( vis[p.se] ) continue;
vis[p.se] = true; for ( int i = head[p.se], v; i; i = graph[i].nxt ) {
LL d = p.fi + graph[i].cst + hgt[p.se] - hgt[v = graph[i].to];
if ( graph[i].flw && dis[v] > d ) {
heap.push( { dis[v] = d, v } );
pre[v] = i, flw[v] = tmin( flw[p.se], graph[i].flw );
}
}
}
return dis[mxp] != LINF;
} int main() {
std::ios::sync_with_stdio( false ), std::cin.tie( 0 ); std::cin >> n;
rep ( i, 1, n ) {
int s, e; LL w; std::cin >> s >> e >> w, ++e;
link( s, e, 1, -w ), mxp = mxp < e ? e : mxp;
}
rep ( i, 0, mxp - 1 ) link( i, i + 1, 2, 0 ); getHeight();
LL ans = 0;
while ( dijkstra() ) {
for ( int u = mxp; u; u = graph[pre[u] ^ 1].to ) {
graph[pre[u]].flw -= flw[mxp], graph[pre[u] ^ 1].flw += flw[mxp];
}
ans += ( dis[mxp] + hgt[mxp] - hgt[0] ) * flw[mxp];
} std::cout << -ans << '\n';
return 0;
}

Solution -「Gym 102759F」Interval Graph的更多相关文章

  1. Solution -「Gym 102956F」Find the XOR

    \(\mathcal{Description}\)   Link.   给定 \(n\) 个点 \(m\) 条边的连通无向图 \(G\),边有边权.其中 \(u,v\) 的距离 \(d(u,v)\) ...

  2. Solution -「Gym 102759I」Query On A Tree 17

    \(\mathcal{Description}\)   Link.   给定一棵含 \(n\) 个结点的树,结点 \(1\) 为根,点 \(u\) 初始有点权 \(a_u=0\),维护 \(q\) 次 ...

  3. Solution -「Gym 102979E」Expected Distance

    \(\mathcal{Description}\)   Link.   用给定的 \(\{a_{n-1}\},\{c_n\}\) 生成一棵含有 \(n\) 个点的树,其中 \(u\) 连向 \([1, ...

  4. Solution -「Gym 102979L」 Lights On The Road

    \(\mathcal{Description}\)   Link.   给定序列 \(\{w_n\}\),选择 \(i\) 位置的代价为 \(w_i\),要求每个位置要不被选择,要不左右两个位置至少被 ...

  5. Solution -「Gym 102956B」Beautiful Sequence Unraveling

    \(\mathcal{Description}\)   Link.   求长度为 \(n\),值域为 \([1,m]\) 的整数序列 \(\lang a_n\rang\) 的个数,满足 \(\not\ ...

  6. Solution -「Gym 102956F」Border Similarity Undertaking

    \(\mathcal{Description}\)   Link.   给定一张 \(n\times m\) 的表格,每个格子上写有一个小写字母.求其中长宽至少为 \(2\),且边界格子上字母相同的矩 ...

  7. Solution -「Gym 102956A」Belarusian State University

    \(\mathcal{Description}\)   Link.   给定两个不超过 \(2^n-1\) 次的多项式 \(A,B\),对于第 \(i\in[0,n)\) 个二进制位,定义任意一个二元 ...

  8. Solution -「Gym 102798I」Sean the Cuber

    \(\mathcal{Description}\)   Link.   给定两个可还原的二阶魔方,求从其中一个状态拧到另一个状态的最小步数.   数据组数 \(T\le2.5\times10^5\). ...

  9. Solution -「Gym 102798K」Tree Tweaking

    \(\mathcal{Description}\)   Link.   给定排列 \(\{p_n\}\),求任意重排 \(p_{l..r}\) 的元素后,将 \(\{p_n\}\) 依次插入二叉搜索树 ...

随机推荐

  1. 微信小程序开发 --- 小白之路 --- 心得

    1.前言 今天 ,发现我的饭卡不见了....悲催 ,看了一下学校的微信小程序,查了下我这饭卡的流水记录,嗯...最后出现的地方在洗澡房... 好吧,扯远了,虽然没找到,可是突发奇想 ,小程序挺方便的, ...

  2. Word2010制作饭店活动宣传单

    原文链接: https://www.toutiao.com/i6492754127343321613/ 打开Word文档,选择"页面布局"选项卡."页面背景"功 ...

  3. 【洛谷】P1067 多项式输出

    原题链接:P1067 多项式输出 题目分析:学长推荐的OJ网站 --洛谷,发现挺好用的还可以下载提交出错的数据. 废话就不多说了,这道题属于基础题.提交出错主要是因为一些小细节不到位,这里就不一一赘述 ...

  4. vmware快速扩容虚拟磁盘

    在使用vmware进行虚拟化的时候,会遇到虚拟磁盘不够用的情况,以前的办法都是使用lvm进行管理扩容,目前在linux上可以实现快速扩容了,具体方法如下: 该方法参考阿里云在线扩容文档:文档地址 其中 ...

  5. Azure Terraform(九)利用 Azure DevOps Pipeline 的审批来控制流程发布

    一,引言 Azure Pipeline 管道是一个自动化过程:但是往往我们由于某种原因,需要在多个阶段之前获得批准之后再继续下一步流程,所以我们可以向Azure Pipeline 管道添加审批!批准流 ...

  6. 设计模式-Java版-全-附代码-超生动实例

    阅读推荐:设计模式-简单篇 项目地址:https://gitee.com/zwtgit/gof23 学习网站推荐: https://refactoringguru.cn/design-patterns ...

  7. AGC041F Histogram Rooks

    有生之年自己做出了一个 AGC F 还踩了标算,但是好像在我之前已经有人踩过标算了,再鞭尸一波也无可厚非 hhh 看到"全部被覆盖" 条件不好做,考虑容斥,即选择若干个位置强制它们 ...

  8. Electron+Vue开发跨平台桌面应用

    Electron+Vue开发跨平台桌面应用 xiangzhihong发布于 2019-12-23 虽然B/S是目前开发的主流,但是C/S仍然有很大的市场需求.受限于浏览器的沙盒限制,网页应用无法满足某 ...

  9. 【刷题-LeetCode】121 Best Time to Buy and Sell Stock

    Best Time to Buy and Sell Stock Say you have an array for which the ith element is the price of a gi ...

  10. es6 快速入门 系列 —— 类 (class)

    其他章节请看: es6 快速入门 系列 类 类(class)是 javascript 新特性的一个重要组成部分,这一特性提供了一种更简洁的语法和更好的功能,可以让你通过一个安全.一致的方式来自定义对象 ...