斜率大法题库

999人阅读 评论(5) 收藏 举报
分类:

[bzoj3675][Apio2014]序列分割

题目大意及模型转换

给定一个由N个元素组成的序列,你现在要对其做M次操作。每次操作如下:
1、选择一个长度大于1的序列,找到任意一个合法位置,将其分割成两个长度不为0的序列。
如[3,2,5,7,8]可以在2后面进行分割变为[3,2]和[5,7,8]。
2、如此做可以获得分数为两个分割后的序列元素之和相乘。
请使总分数最大。
每个元素都为正数,n<=100000,k<=min(n-1,200)。

DP做法

我们应该意识到切的先后顺序是没有用的。
设f[i,k]表示前i个元素被分割了k次,获得的最大总分。
设sum[i]表示1到i元素的前缀和。
显然f[i,k]=max(f[j,k1]+sum[j](sum[i]sum[j]))
这个DP可以在O(N2M)

斜率大法好

我们可以固定一个k,然后看看是否可以进行斜率优化。
固定k后我们固定一个i,然后比较决策j优于决策l的条件。

f[j,k1]+sum[j]sum[i]sum[j]2>f[l,k1]+sum[l]sum[i]sum[l]2
f[j,k1]f[l,k1]+sum[l]2sum[j]2>sum[i](sum[l]sum[j])
f[j,k1]f[l,k1]+sum[l]2sum[j]2sum[l]sum[j]>sum[i]

那么我们左边与i无关。
每个元素都是正数,右边的sum[i]会递增。
为了保证sum[l]-sum[j]>0,因此要保证j<l。
我们开单调队列。
那么新加入的放队尾,最优的取队头。
对于固定的k。
g(j,l)=f[j,k1]f[l,k1]+sum[l]2sum[j]2sum[l]sum[j]
那么单调队列内需保证相邻三元素,前两个的g值小于后两个的g值。
复杂度O(NM)

[火影完结纪念赛]木叶的军师

题目大意及模型转换

给定N个正整数,要求分成M组。每组带来的价值为这组的最大值与最小值差的平方。请使总价值最小。n<=10000,m<=5000。

DP做法

可以贪心的得知,排个序以后,连续的分成一组一定最优。
设f[i,k]表示前i个数分成k组最小总价值。
f[i,k]=min(f[j,k1]+(a[i]a[j+1])2)

斜率大法好

同第一题,固定k与i,那么j和l哪个优呢?
设j优于l,需满足:
f[j,k1]+(a[i]a[j+1])2<f[l,k1]+(a[i]a[l+1])2

f[j,k1]f[l,k1]+a[j+1]2a[l+1]2<2a[i](a[j+1]a[l+1])

f[j,k1]f[l,k1]+a[j+1]2a[l+1]2a[j+1]a[l+1]>2a[i]

注意为什么变号。
因为我们要j<l。排序后a[j+1]-a[l+1]<=0。
对于等于0的情况,我们进行合并(容易得知合并后不会造成什么影响,因为相同的一定分在同一组)。
那么小于0,两端相除一个负数,自然要进行变号。

待补充

查看评论

中国人自己的开发语言HB++<语句介绍>

这些是基本的开发语言语句,HB++对面向对象作了不少支持工作,在这方面,比VB.NET最新版的面向对象支持方面更加出色.这里将分段介绍HB++,供同行业朋友指正和帮助3.2 语句1. 顺序语句a) 赋...
  • yoursoft
  • yoursoft
  • 2001-06-18 17:07:00
  • 1097

斜率优化总结&基础题表

斜率优化
  • u010336344
  • u010336344
  • 2016-09-28 21:42:23
  • 2332

O S G I 阅读笔记

  • 2008年10月10日 09:18
  • 194KB
  • 下载

google大法!

----------------------------------------------------------------------------------------------------...
  • wjy397
  • wjy397
  • 2016-03-02 11:47:45
  • 418

sql语句操作之cv大法全集

 下列语句部分是Mssql语句,不可以在access中使用。SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT,DELETE,...
  • menhal
  • menhal
  • 2007-10-09 14:50:00
  • 578

Android手机提速6大法

  • 2011年05月13日 14:30
  • 1MB
  • 下载

Python大法好

话说今年用户大会本来没我啥事了,然后发现Python没人讲,就说虾神你来把——我刚刚答应,做了三分之一的PPT和DEMO之后,领导体贴的通知我,说体贴一下老员工,给你安排其他同学了,你可以歇了……好吧...
  • allenlu2008
  • allenlu2008
  • 2016-08-11 10:26:23
  • 1920

实验吧CTF刷题记录(web篇)

1.这个看起来有点简单 解题链接: http://ctf5.shiyanbar.com/8/index.php?id=1 手工检测是否存在sql注入 使用sqlmap爆出当前数据库my_db 发现...
  • sinat_21923549
  • sinat_21923549
  • 2017-03-10 10:55:37
  • 3388

AnyFo_-_ExtJS_移魂大法

  • 2010年08月11日 22:38
  • 619KB
  • 下载

OpenCV中的onMouse事件、ROI区域设置、直线斜率检测

//crop:probe1.bmp source:canny_probe.jpg #include "stdafx.h" #include "cv.h" #include "cxcore...
  • gududeyhc
  • gududeyhc
  • 2013-05-23 22:19:13
  • 1908
    个人资料
    专栏达人 持之以恒
    等级:
    访问量: 39万+
    积分: 1万+
    排名: 1455
    最新评论
    文章分类