Solution -「ABC 219H」Candles
\(\mathcal{Description}\)
Link.
有 \(n\) 支蜡烛,第 \(i\) 支的坐标为 \(x_i\),初始长度为 \(a_i\),每单位时间燃烧变短 \(1\) 直到长度为 \(0\)。你从 \(0\) 位置出发,每次可以向左或向右走 \(1\) 单位,走到一个蜡烛的位置可以吹熄蜡烛。求最多能保留的蜡烛长度之和。
\(n\le300\)。
\(\mathcal{Solution}\)
和 甲虫 这题比较像,可以说是相同思路的不同实现方法。问题的核心自然是费用提前计算,我们需要知道想要吹熄的蜡烛数量才能计算当前行动一步带来的总长度损失。注意到 \(n\) 较小,可以直接把这一信息记入状态。
具体地,加入一支 \(x_{n+1}=a_{n+1}=0\) 的蜡烛,设按坐标排序后该蜡烛的下标为 \(p\)。令 \(f(l,r,0/1,k)~([l,r]\ni p,k\in[0,n])\) 表示当前经过了区间 \([l,r]\) 内的蜡烛位置,停留在 \(l/r\),还希望在这个区间以外获得 \(k\) 支蜡烛。通过忽略“蜡烛长度非负”这一限制,把最大化最大值转化成最大化任意值,可以轻松 DP 求解。复杂度 \(\mathcal O(n^3)\)。
\(\mathcal{Code}\)
/*~Rainybunny~*/
#include <bits/stdc++.h>
#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<int, int> PII;
#define fi first
#define se second
const int MAXN = 300;
const LL LINF = 1ll << 60;
int n;
LL f[MAXN + 5][MAXN + 5][2][MAXN + 5];
PII cdl[MAXN + 5];
inline LL dabs( const LL u ) { return u < 0 ? -u : u; }
inline void chkmax( LL& u, const LL v ) { u < v && ( u = v ); }
int main() {
scanf( "%d", &n ), ++n;
rep ( i, 2, n ) scanf( "%d %d", &cdl[i].fi, &cdl[i].se );
std::sort( cdl + 1, cdl + n + 1 );
int p = std::lower_bound( cdl + 1, cdl + n + 1, PII( 0, 0 ) ) - cdl;
rep ( i, 1, n ) rep ( j, i + 1, n ) rep ( t, 0, 1 ) rep ( k, 0, n ) {
f[i][j][t][k] = -LINF;
}
rep ( i, 0, n ) f[p][p][0][i] = 0;
LL ans = 0;
rep ( len, 0, n - 1 ) {
for ( int i = 0, l, r; i <= len; ++i ) {
if ( ( l = p - i ) <= 0 || ( r = p + len - i ) > n ) continue;
int x[2] = { cdl[l].fi, cdl[r].fi };
rep ( t, 0, 1 ) {
rep ( k, 0, n ) {
LL cur = f[l][r][t][k];
if ( cur == -LINF ) continue;
if ( !k ) { chkmax( ans, cur ); continue; }
if ( l > 1 ) {
chkmax( f[l - 1][r][0][k - 1], cur + cdl[l - 1].se
- dabs( x[t] - cdl[l - 1].fi ) * k );
chkmax( f[l - 1][r][0][k], cur
- dabs( x[t] - cdl[l - 1].fi ) * k );
}
if ( r < n ) {
chkmax( f[l][r + 1][1][k - 1], cur + cdl[r + 1].se
- dabs( x[t] - cdl[r + 1].fi ) * k );
chkmax( f[l][r + 1][1][k], cur
- dabs( x[t] - cdl[r + 1].fi ) * k );
}
}
}
}
}
printf( "%lld\n", ans );
return 0;
}
Solution -「ABC 219H」Candles的更多相关文章
- Solution -「ABC 215H」Cabbage Master
\(\mathcal{Description}\) Link. 有 \(n\) 种颜色的,第 \(i\) 种有 \(a_i\) 个,任意两球互不相同.还有 \(m\) 个盒子,每个盒子可以被放 ...
- Solution -「ABC 213G」Connectivity 2
\(\mathcal{Description}\) Link. 给定简单无向图 \(G=(V,E)\),点的编号从 \(1\) 到 \(|V|=n\).对于 \(k=2..n\),求 \(H= ...
- Solution -「ABC 213H」Stroll
\(\mathcal{Description}\) Link. 给定一个含 \(n\) 个结点 \(m\) 条边的简单无向图,每条边的边权是一个常数项为 \(0\) 的 \(T\) 次多项式, ...
- Solution -「ABC 217」题解
D - Cutting Woods 记录每一个切割点,每次求前驱后驱就好了,注意简单判断一下开闭区间. 考场上采用的 FHQ_Treap 无脑莽. #include <cstdio> #i ...
- Solution -「ARC 104E」Random LIS
\(\mathcal{Description}\) Link. 给定整数序列 \(\{a_n\}\),对于整数序列 \(\{b_n\}\),\(b_i\) 在 \([1,a_i]\) 中等概率 ...
- Solution Set -「ABC 217」
大家好屑兔子又来啦! [A - Lexicographic Order] 说个笑话,\(\color{black}{\text{W}}\color{red}{\text{alkingDead} ...
- Solution -「ARC 110E」Shorten ABC
\(\mathcal{Description}\) Link. 给定长度为 \(n\),包含 A, B, C 三种字符的字符串 \(S\),定义一次操作为将其中相邻两个不相同的字符替换为字符集 ...
- Solution -「CTS 2019」「洛谷 P5404」氪金手游
\(\mathcal{Description}\) Link. 有 \(n\) 张卡牌,第 \(i\) 张的权值 \(w_i\in\{1,2,3\}\),且取值为 \(k\) 的概率正比于 \ ...
- Solution -「BZOJ 3812」主旋律
\(\mathcal{Description}\) Link. 给定含 \(n\) 个点 \(m\) 条边的简单有向图 \(G=(V,E)\),求 \(H=(V,E'\subseteq E)\ ...
随机推荐
- java 封装 总结
1.前言 老是被问什么是java 封装...很基础的一个问题 ,其实我们一直在写的东西但不知道怎么称呼. 比如 在entity实体类 里面老用到的 getter 和 setter 方法其实就是封装的方 ...
- Java Date 类型比较
//某时间Date time = tRemind.getTime();//现在时间Date now = new Date();//结果大于0则是现在时间大于某时间//结果等于0则为刚好相等//结果小于 ...
- js字符串首字母大写的不同写法
写法一: let name = 'hello' name.charAt(0).toUpperCase() + name.slice(1) 写法二: let name = 'hello' name.sl ...
- 论文翻译:2020_RESIDUAL ACOUSTIC ECHO SUPPRESSION BASED ON EFFICIENT MULTI-TASK CONVOLUTIONAL NEURAL NETWORK
论文翻译:https://arxiv.53yu.com/abs/2009.13931 基于高效多任务卷积神经网络的残余回声抑制 摘要 在语音通信系统中,回声会降低用户体验,需要对其进行彻底抑制.提出了 ...
- nginx代理图片上传以及访问 nginx 图片上传完整版
nginx代理图片上传 首先需要利用nginx代理图片访问参考 https://www.cnblogs.com/TJ21/p/12609017.html 编写接受文件的controller 1 @Po ...
- K8s中的volumes-容器数据存放类型及位置
学习对象:kubectl explain pod.spec.volumes.pod.spec.containers.image.volumeMounts 介绍Volumes 容器内部也有自己的空间,但 ...
- winform 中心旋转 图片旋转
//设置左上角到中心点 g.TranslateTransform(int.Parse(x), int.Parse(y)); //旋转角度 g.RotateTransform(int.Parse(&qu ...
- 微服务架构 | 12.1 使用 Apache Dubbo 实现远程通信
目录 前言 1. Dubbo 基础知识 1.1 Dubbo 是什么 1.2 Dubbo 的架构图 1.3 Spring Cloud 与 Dubbo 的区别 1.4 Dubbo 的特点 1.5 Dubb ...
- gin中获取查询字符串参数
package main import ( "github.com/gin-gonic/gin" "net/http" ) func main() { r := ...
- For Update 加锁分析
MySQL InnoDB 锁 - For Update 加锁分析: 1. InnoDB锁 简单介绍 2. 当前读加锁分析:REPEATABLE-READ 可重复读.READ-COMMITTED 读已提 ...