D - Pearls HDU - 1300 斜率dp+二分
D - Pearls
这个题目也是一个比较裸的斜率dp,依照之前可以推一下这个公式,这个很好推
这个注意题目已经按照价格升序排列序,所以还是前缀和还是单调的。
sum[i] 表示前面 i 种珍珠的花费的前缀和
dp[i]表示买前面 i 种珍珠需要的最少的花费
dp[i]=min(dp[j]+(sum[i]-sum[j]+10)*c[i]
j>k 如果要求选 j 更优,则需要满足下列式子
dp[j]+(sum[i]-sum[j]+10)*c[i]<dp[k]+(sum[i]-sum[j]+10)*c[i]
上面式子化简可得
dp[j]-dp[k]<c[i]*(sum[j]-sum[k])
令G[j,k]=(dp[j]-dp[k])/(sum[j]-sum[k])
如果G[j,k]<c[i]且j>k 则选 j 比选 k 更优
推出这个斜率的式子之后,然后要用它。
关键的来了:现在从左到右,还是设k<j<i,如果g[i,j]<g[j,k],那么j点便永远不可能成为最优解,可以直接将它踢出我们的最优解集。为什么呢?
分三种情况讨论
1 G[i,j]<G[j,k]<c[t] 那么 i 是比 j 更优的 所以可以排除 j 点
2 G[i,j]<c[t]<G[j,k] 那么 i 也是比 j 更优的,而且 k 比 j 也优 可以排除 j 点
3 c[t]<G[i,j]<G[j,k] 那么 k 是比 j 更优 可以排除 j 点
所以如果是G[i,j]<G[j,k] 且 i>j>k 那么就可以排除掉 j 这个情况,因为 j 两边永远可以找到一个比它更优的,这个也是一种优化
那如果 G[i,j]>G[j,k] i>j>k 这种情况呢?
1 G[i,j]>G[j,k] >c[t] 那么 j 比 i 更优 k 比 j 更优
2 G[i,j]>c[t]>G[j,k] 那么 j 比 i 更优 j 也比 k 更优
3 c[t]>G[i,j]>G[j,k] 那么 i 比 j 更优 j 比 k 更优
这个就可以找到单调性了,
如果 i 从小往大 G[i,j] 越来越大,那么在 小于等于 c[t] 的范围内,情况也更优,
意思是 如果 i>j>k 如果可以在 j 点取得最优解,那么k点肯定可以排除,
所以就是找小于 c[t] 的最大的这个 j 。
如果是G[i,j]<Gj,k]&&i>j>k 这种情况可以找到一个 j 比两端都优的
因为这个题目c是单调递增的,所以可以用单调队列来维护。
- #include <cstdio>
- #include <cstring>
- #include <cstdlib>
- #include <algorithm>
- #include <queue>
- #include <vector>
- #include <string>
- #define inf 0x3f3f3f3f
- #define inf64 0x3f3f3f3f3f3f3f3f
- using namespace std;
- const int maxn = 1e3 + ;
- typedef long long ll;
- ll dp[maxn], sum[maxn], c[maxn];
- int que[maxn];
- ll up(int i,int j)
- {
- return dp[i] - dp[j];
- }
- ll down(int i,int j)
- {
- return sum[i] - sum[j];
- }
- ll DP(int i,int j)
- {
- return dp[j] + (sum[i] - sum[j] + )*c[i];
- }
- int main()
- {
- int t;
- scanf("%d", &t);
- while(t--)
- {
- int n;
- scanf("%d", &n);
- sum[] = dp[] = ;
- for (int i = ; i <= n; i++) scanf("%lld%lld", &sum[i], &c[i]), sum[i] += sum[i - ];
- int head = , tail = ;
- que[tail++] = ;
- for(int i=;i<=n;i++)
- {
- while (head + < tail&&up(que[head + ], que[head]) <= c[i] * down(que[head + ], que[head])) head++;//如果满足这个式子
- //就是说明que[head+1]比 que[head]更优,所以可以删去这个que[head] 然后之后不满足这个式子了,说明que[head]比que[head+1]更优
- //说明这个时候的队首就是最优的,就可以跳出循环
- dp[i] = DP(i, que[head]);
- while (head + < tail&&up(i, que[tail - ])*down(que[tail - ], que[tail - ]) <= up(que[tail - ], que[tail - ])*down(i, que[tail - ])) tail--;
- que[tail++] = i;
- }
- printf("%lld\n", dp[n]);
- }
- return ;
- }
D - Pearls HDU - 1300 斜率dp+二分的更多相关文章
- B - Lawrence HDU - 2829 斜率dp dp转移方程不好写
B - Lawrence HDU - 2829 这个题目我觉得很难,难在这个dp方程不会写. 看了网上的题解,看了很久才理解这个dp转移方程 dp[i][j] 表示前面1~j 位并且以 j 结尾分成了 ...
- hdu2993之斜率dp+二分查找
MAX Average Problem Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- hdu 3507 斜率dp
不好理解,先多做几个再看 此题是很基础的斜率DP的入门题. 题意很清楚,就是输出序列a[n],每连续输出的费用是连续输出的数字和的平方加上常数M 让我们求这个费用的最小值. 设dp[i]表示输出前i个 ...
- hdu 2829 斜率DP
思路:dp[i][x]=dp[j][x-1]+val[i]-val[j]-sum[j]*sum[i]+sum[j]*sum[j]; 其中val[i]表示1~~i是一段的权值. 然后就是普通斜率dp做法 ...
- hdu 3586 树形dp+二分
题目大意:给定n个敌方据点,1为司令部,其他点各有一条边相连构成一棵 树,每条边都有一个权值cost表示破坏这条边的费用,叶子节点为前线.现要切断前线和司令部的联系,每次切断边的费用不能超过上限lim ...
- HDU 3480 斜率dp
Division Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 999999/400000 K (Java/Others)Total ...
- HDU - 1300 简单DP
题意:买珠子的方案有两种,要么单独买,价钱为该种类数量+10乘上相应价格,要么多个种类的数量相加再+10乘上相应最高贵的价格买 坑点:排序会WA,喵喵喵? 为什么连续取就是dp的可行方案?我猜的.. ...
- hdu 2993 斜率dp
思路:直接通过斜率优化进行求解. #include<iostream> #include<cstdio> #include<algorithm> #include& ...
- hdu 4258 斜率DP
思路:dp[i]=dp[j]+(num[i]-num[j+1])^2; #include<iostream> #include<cstring> #include<alg ...
随机推荐
- Java异常处理总结Exception\Error
Java异常处理总结Exception\Error 2012-12-28 08:17:17| 分类: JAVA | 标签:java |举报|字号 订阅 Java异常处理总结 ...
- 玩家的numpertpry 对象 中 不仅仅要同步 君主武将的等级,阶级也要同步
因为好多列表 中 需要 批量查询 玩家的等级 和阶级(用来显示玩家icon颜色用的),如果阶级 在numperty 中已同步 的话,就不用批量去查玩家武将列表了.同理如果其他属性也经常用的话也可以同步 ...
- 从前端到后端实现弹幕的过程(jsp/Jquery.barrager.js)
Jquery.barrager.js插件,可以去网上下载!下载完后,就把下载文件中的js文件.css文件.图片文件.等等等文件全部拷贝到你们自己的项目中去,千万别拷贝漏了,如果你怕拷贝漏了什么,那就把 ...
- cool-yogurt小组采访感想
“对于这个小组项目的选题,其实最初的那个版本我还是被“感动”到的,因为我自己以前确实有这样的类似体验和需求,以前非常喜欢一个球星,因此想知道关于他所有的事情,想知道他每一场比赛的数据,新闻有哪些报道, ...
- vue中的错误日志
一.Error compiling template: Component template requires a root element, rather than just text. 这个错误意 ...
- Java 8 到 Java 14,改变了哪些你写代码的方式?
前几天,JDK 14 正式发布了,这次发布的新版本一共包含了16个新的特性. 其实,从Java8 到 Java14 ,真正的改变了程序员写代码的方式的特性并不多,我们这篇文章就来看一下都有哪些. La ...
- vue2.x学习笔记(二十三)
接着前面的内容:https://www.cnblogs.com/yanggb/p/12639440.html. 渲染函数&JSX 基础 vue推荐在绝大多数的情况下使用模板来创建html.然而 ...
- 使用 selenium 实现谷歌以图搜图爬虫
使用selenium实现谷歌以图搜图 实现思路 原理非常简单,就是利用selenium去操作浏览器,获取到想要的链接,然后进行图片的下载,和一般的爬虫无异. 用到的技术:multiprocessing ...
- MVC-路由扩展-限制浏览器
根据路由原理,MVC每次都会走获取路由上下文数据. 自定义Route 调用,以及完善其他代码 运行结果,当在谷浏览器执行时:
- Mac安装aws-cli全过程,通过命令行上传文件到aws s3协议服务器
第一次使用aws,首先查询了各种资料,我第一步需要做的是安装aws-cli,而安装aws-cli之前需要安装python3,当然你安装python3之前你还需要安装homebrew,当然我正在安装的过 ...