码迷,mamicode.com
首页 > 其他好文 > 详细

CodeForces 1131G. Most Dangerous Shark

时间:2019-02-24 18:52:42      阅读:232      评论:0      收藏:0      [点我收藏+]

标签:ORC   har   http   mos   单调栈   动态   code   ssi   .com   

题目简述:从左到右依次有$n \leq 10^7$个Domino骨牌,高度为$h_i$,手动推倒他的花费为$c_i$。每个骨牌之间的距离为$1$。一个骨牌可以被向左或者向右推倒。当第$i$个骨牌被推倒时,他会以相同方向推倒与其距离$<h_i$的所有骨牌。求推倒所有骨牌的最小花费。

解:code

令$L[i], R[i]$分别表示第$i$个骨牌向左(右)推倒后,会将$(L[i], i]$($[i, R[i])$)区间内的骨牌推倒。这个可以用单调栈在$O(n)$时间内解决。

令$f[i]$表示(只通过推倒前$i$个骨牌来)推倒前$i$个骨牌的最小花费,则对$1 \leq i \leq n$,

$$ f[i] = \min\left\{ f[L[i]]+c_i, \min_{j < i < R[j]} \{f[j-1]+c_j\} \right\}, $$

这个动态规划也能用单调栈在$O(n)$时间内解决。

CodeForces 1131G. Most Dangerous Shark

标签:ORC   har   http   mos   单调栈   动态   code   ssi   .com   

原文地址:https://www.cnblogs.com/TinyWong/p/10427161.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!