WA了一版...

切点确定的话, 顺序是不会影响结果的..所以可以dp

dp(i, k) = max(dp(j, k-1) + (sumn - sumi) * (sumi - sumj)) 然后斜率优化就可以了...

--------------------------------------------------------------------------------

#include<cstdio>
#include<algorithm>
#include<cstring>
#include<queue>
 
using namespace std;
 
typedef long long ll;
 
const int maxn = 100009;
 
ll dp[maxn][2], sum[maxn];
int N, K, q[maxn], c = 0, p = 1;
 
int main() {
scanf("%d%d", &N, &K);
sum[0] = 0;
for(int i = 1; i <= N; i++) {
scanf("%lld", sum + i);
sum[i] += sum[i - 1];
}
for(int i = 1; i <= N; i++)
dp[i][c] = sum[i] * (sum[N] - sum[i]);
for(int k = 2; k <= K; k++) {
swap(c, p);
int qh = 0, qt = 0;
q[0] = k - 1;
for(int i = k; i < N; i++) {
ll A = sum[N] - sum[i];
while(qh < qt && dp[q[qh + 1]][p] - dp[q[qh]][p] > (double) A * (sum[q[qh + 1]] - sum[q[qh]])) qh++;
dp[i][c] = dp[q[qh]][p] + A * (sum[i] - sum[q[qh]]);
while(qt - qh > 0 && (double) (dp[i][p] - dp[q[qt]][p]) * (sum[q[qt]] - sum[q[qt - 1]]) >= (double) (dp[q[qt]][p] - dp[q[qt - 1]][p]) * (sum[i] - sum[q[qt]])) qt--;
q[++qt] = i;
}
}
ll ans = 0;
for(int i = K; i < N; i++) ans = max(ans, dp[i][c]);
printf("%lld\n", ans);
return 0;
}

--------------------------------------------------------------------------------

3675: [Apio2014]序列分割

Time Limit: 40 Sec  Memory Limit: 128 MB
Submit: 1101  Solved: 438
[Submit][Status][Discuss]

Description

小H最近迷上了一个分割序列的游戏。在这个游戏里,小H需要将一个长 
度为N的非负整数序列分割成k+l个非空的子序列。为了得到k+l个子序列, 
小H将重复进行七次以下的步骤: 
1.小H首先选择一个长度超过1的序列(一开始小H只有一个长度为n的 
序列一一也就是一开始得到的整个序列); 
2.选择一个位置,并通过这个位置将这个序列分割成连续的两个非空的新 
序列。 
每次进行上述步骤之后,小H将会得到一定的分数。这个分数为两个新序 
列中元素和的乘积。小H希望选择一种最佳的分割方案,使得k轮(次)之后, 
小H的总得分最大。

Input

输入文件的第一行包含两个整数n和尼(k+1≤n)。 
第二行包含n个非负整数a1,n2….,an(0≤ai≤10^4),表示一开始小H得 
到的序列。

Output

一行包含一个整数,为小H可以得到的最大得分。

Sample Input

7 3
4 1 3 4 0 2 3

Sample Output

108

HINT

【样例说明】

在样例中,小H可以通过如下3轮操作得到108分:

1.-开始小H有一个序列(4,1,3,4,0,2,3)。小H选择在第1个数之后的位置

将序列分成两部分,并得到4×(1+3+4+0+2+3)=52分。

2.这一轮开始时小H有两个序列:(4),(1,3,4,0,2,3)。小H选择在第3个数

字之后的位置将第二个序列分成两部分,并得到(1+3)×(4+0+2+

3)=36分。

3.这一轮开始时小H有三个序列:(4),(1,3),(4,0,2,3)。小H选择在第5个

数字之后的位置将第三个序列分成两部分,并得到(4+0)×(2+3)=

20分。

经过上述三轮操作,小H将会得到四个子序列:(4),(1,3),(4,0),(2,3)并总共得到52+36+20=108分。

【数据规模与评分】

:数据满足2≤n≤100000,1≤k≤min(n -1,200)。

Source

BZOJ 3675: [Apio2014]序列分割( dp + 斜率优化 )的更多相关文章

  1. BZOJ 3675 [Apio2014]序列分割 (斜率优化DP)

    题目链接 BZOJ 3675 首先最后的答案和分割的顺序是无关的, 那么就可以考虑DP了. 设$f[i][j]$为做了$i$次分割,考虑前$j$个数之后的最优答案. 那么$f[i][j] = max( ...

  2. bzoj 3675: [Apio2014]序列分割【斜率优化dp】

    首先看这个得分方式,容易发现就相当于分k段,每段的值和两两乘起来. 这样就很容易列出dp方程:设f[i][j]为到j分成分成i段,转移是 \[ f[i][j]=max { f[k][j]+s[k]*( ...

  3. BZOJ 3675: [Apio2014]序列分割 动态规划 + 斜率优化 + 卡精度

    Code: #include<bits/stdc++.h> #define N 100006 #define M 205 #define ll long long #define setI ...

  4. bzoj 3675 [Apio2014]序列分割(斜率DP)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3675 [题意] 将n个数的序列分割k次,每次的利益为分割后两部分数值和的积,求最大利益 ...

  5. BZOJ_3675_[Apio2014]序列分割_斜率优化

    BZOJ_3675_[Apio2014]序列分割_斜率优化 Description 小H最近迷上了一个分隔序列的游戏.在这个游戏里,小H需要将一个长度为n的非负整数序列分割成k+1个非空的子序列.为了 ...

  6. 【斜率DP】BZOJ 3675:[Apio2014]序列分割

    3675: [Apio2014]序列分割 Time Limit: 40 Sec  Memory Limit: 128 MBSubmit: 1066  Solved: 427[Submit][Statu ...

  7. BZOJ3675 [Apio2014]序列分割 【斜率优化dp】

    3675: [Apio2014]序列分割 Time Limit: 40 Sec  Memory Limit: 128 MB Submit: 3366  Solved: 1355 [Submit][St ...

  8. 【BZOJ-3675】序列分割 DP + 斜率优化

    3675: [Apio2014]序列分割 Time Limit: 40 Sec  Memory Limit: 128 MBSubmit: 1420  Solved: 583[Submit][Statu ...

  9. [Bzoj3675][Apio2014]序列分割(斜率优化)

    3675: [Apio2014]序列分割 Time Limit: 40 Sec  Memory Limit: 128 MBSubmit: 4021  Solved: 1569[Submit][Stat ...

随机推荐

  1. MySQL 创建用户与修改密码

    创建用户的 3 方法: 1 .create user userName identifed by 'yourPassword'; 2. grant select on *.* to userName@ ...

  2. 6_StopWatch

    6 // // ViewController.swift // StopWatch // // Created by ZC on 16/1/9. // Copyright © 2016年 ZC. Al ...

  3. 如何取消一个本地svn目录与svn的联系(即恢复原有图标等)

    在使用svn 的时候容易手抖错选update地址,使其目录所有同级文件夹上出现蓝色“?”图样,非常烦人,下面记录一下解决方案. 首先在该目录下打开同级文件件,工具→文件夹选项→查看→隐藏文件和文件夹→ ...

  4. Q_D宏

    Qt 源码中有很多Q_Q和Q_D宏,使用这些宏的地方总会看到有q指针和d指针,查了查KDE文档,大体搞清了其中的机理,欧也!Qt的这些私有数据访问策略还是挺值得借鉴.下面就简单总结一下. 访问器 , ...

  5. opencv-python 学习笔记1:简单的图片处理

    一.主要函数 1. cv2.imread():读入图片,共两个参数,第一个参数为要读入的图片文件名,第二个参数为如何读取图片,包括cv2.IMREAD_COLOR:读入一副彩色图片:cv2.IMREA ...

  6. zombie-phantom

    zombie-phantom zombie-phantom Provides a Zombie.js shim around the PhantomJS Headless Browser. npm i ...

  7. 从Android中Activity之间的通信说开来[转]

    http://www.cnblogs.com/virusswb/archive/2011/08/02/2124824.html 引言 最近两个星期在研究android的应用开发,学习了android应 ...

  8. 去掉android的屏幕上的title bar

    在配置文件里修改 (关键代码:android:theme="@android:style/Theme.NoTitleBar.Fullscreen",如果想只是去除标题栏就后面不用加 ...

  9. 苹果 App 转移图文详解

    目前公司在做App转移操作,在网上搜索相关资料加上自己的亲自操作,整理成一个文档,希望能给你提供帮助. 如转载请添加出处. 此文章只是为了记录一个Apple ID下的APP,转移到另外一个Apple ...

  10. .NET中的IO操作基础介绍

    关于IO简介 .NET中的IO操作,经常需要调用一下几个类. clipboard[] .FileStream类 文件流类,负责大文件的拷贝,读写. .Path类 Path类中方法,基本都是对字符串(文 ...