原文链接http://www.cnblogs.com/zhouzhendong/p/9004583.html

题目传送门 - Codechef CHSIGN

题意

  第一行,一个数$T$,表示数据组数。

  对于每一组数据,给定一个$n$,接下来是一个长度为$n$的数列$a$,$a$的第$i$项为$a_i$。

  所有$a_i$都是正整数。现在你可以选择若干个不同的$a_i$使他取相反数,但是你需要保证修改后的序列的任意一段长度大于$1$的连续自序列的数字总和都为正数。在满足条件的基础上,最小化修改之后$\sum_{i=1}^n a_i$,并输出方案。

  $T,n\leq 10^5,\ \sum n \leq 5\times 10^5,\ a_i\leq 10^9$

题解

  对操作之后的序列求前缀和之后,我们可以得出以下结论:

  $s_i>s_{i-2}\ \ \ \ (i=2)$

  $s_i>s_{i-2}且s_i>s_{i-3}\ \ \ (2<i\leq n)$

  而且,显然,被修改的$a_i$必然满足$a_i>a_{i-1},\ a_i>a_{i+1}$(当$i=1或i=n$的时候稍微特殊)。

  设$dp_i$为处理了$a_{1\cdots i}$且修改了$a_i$时,保证前$i$个元素构成的子序列合法,$\sum a_{1\cdots i}$的最大值。

  先不考虑转移条件,列出转移方程:

$$dp_i=\min(dp_j-s_j+s_i-2a_i)$$(这里的$s$指$a$被修改之前的$s$,不要和之前提到的$s$混淆,后面的也要注意。)

  然后我们来罗列一下条件:

  对于$i$,满足$a_i>a_{i-1},\ a_i>a_{i+1}$。

  于是第$i-1$个元素不能被修改,故$j<i-1$。

  当$j=i-2$时,需要满足$-a_{i-2}+a_{i-1}-a{i}>0$。

  当$j<i-2$时,由于$a_i>a_{i-1},\ a_i>a_{i+1}$,所以$s_{i}>s_{i-2},\ s_{i}>s_{i-3}$且$s_{i+1}>s_{i-1},\ s_{i+1}>s_{i-2}$(太显然了,自己验证)。所以只要$j<i-2$就可以转移。于是我们只需要对$dp_j-s_j$取个前缀$\min$即可。

  至于求方案这个没什么思维含量就不说了。

代码

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const int N=100005;
const LL INF=1LL<<57;
int T,n;
LL a[N],s[N],dp[N],f[N],Min[N];
LL cc(int i){
return dp[i]-s[i];
}
int main(){
scanf("%d",&T);
while (T--){
scanf("%d",&n);
for (int i=1;i<=n;i++)
scanf("%lld",&a[i]),s[i]=s[i-1]+a[i];
a[n+1]=INF;
LL ans=0;
dp[0]=0;
dp[1]=a[2]>a[1]?-a[1]:a[1];
Min[0]=0;
Min[1]=cc(1)<cc(0)?1:0;
for (int i=1;i<=n;i++){
if (i>=2){
dp[i]=INF;
if (a[i]<a[i-1]&&a[i]<a[i+1]){
if (-a[i-2]+a[i-1]-a[i]>0)
if (dp[i-2]+s[i]-s[i-2]-2*a[i]<dp[i]){
dp[i]=dp[i-2]+s[i]-s[i-2]-2*a[i];
f[i]=i-2;
}
if (i-3>=0)
if (cc(Min[i-3])+s[i]-2*a[i]<dp[i]){
dp[i]=cc(Min[i-3])+s[i]-2*a[i];
f[i]=Min[i-3];
}
}
Min[i]=cc(Min[i-1])>cc(i)?i:Min[i-1];
}
if (dp[i]+s[n]-s[i]<dp[ans]+s[n]-s[ans])
ans=i;
}
for (int i=ans;i;i=f[i])
a[i]=-a[i];
for (int i=1;i<=n;i++)
printf("%lld ",a[i]);
puts("");
}
return 0;
}
/*
dp[i]=min(dp[j]+s[i]-s[j]-2*a[i])
a[i]<a[i-1],a[i]<a[i+1]
j==i-2,-a[i-2]+a[i-1]-a[i]>0
j<i-2,显然可以
*/

  

Codechef CHSIGN Change the Signs(May Challenge 2018) 动态规划的更多相关文章

  1. Codechef October Challenge 2018 游记

    Codechef October Challenge 2018 游记 CHSERVE - Chef and Serves 题目大意: 乒乓球比赛中,双方每累计得两分就会交换一次发球权. 不过,大厨和小 ...

  2. Codechef September Challenge 2018 游记

    Codechef September Challenge 2018 游记 Magician versus Chef 题目大意: 有一排\(n(n\le10^5)\)个格子,一开始硬币在第\(x\)个格 ...

  3. Codeforces Avito Code Challenge 2018 D. Bookshelves

    Codeforces Avito Code Challenge 2018 D. Bookshelves 题目连接: http://codeforces.com/contest/981/problem/ ...

  4. Lyft Level 5 Challenge 2018 - Final Round (Open Div. 2) (前三题题解)

    这场比赛好毒瘤哇,看第四题好像是中国人出的,怕不是dllxl出的. 第四道什么鬼,互动题不说,花了四十五分钟看懂题目,都想砸电脑了.然后发现不会,互动题从来没做过. 不过这次新号上蓝名了(我才不告诉你 ...

  5. codechef February Challenge 2018 简要题解

    比赛链接:https://www.codechef.com/FEB18,题面和提交记录是公开的,这里就不再贴了 Chef And His Characters 模拟题 Chef And The Pat ...

  6. Codechef STMINCUT S-T Mincut (CodeChef May Challenge 2018) kruskal

    原文链接http://www.cnblogs.com/zhouzhendong/p/9010945.html 题目传送门 - Codechef STMINCUT 题意 在一个有边权的无向图中,我们定义 ...

  7. Codechef August Challenge 2018 : Chef at the River

    传送门 (要是没有tjm(Sakits)的帮忙,我还真不知道啥时候能做出来 结论是第一次带走尽可能少的动物,使未带走的动物不冲突,带走的这个数量就是最优解. 首先这个数量肯定是下界,更少的话连第一次都 ...

  8. Codechef August Challenge 2018 : Safe Partition

    传送门 (虽然是A了但是不知道复杂度是不是正确的 考虑以某个位置为结尾的合法划分 先考虑min,带来的影响是限制了最小长度,预处理出这个最小长度后,这可以在处理到这个数时,把不能算的部分去掉(不满足m ...

  9. Codechef August Challenge 2018 : Interactive Matrix

    传送门 首先整个矩阵可以被分为很多小矩阵,小矩阵内所有行的单调性是一样的,所有列的单调性是一样的. 考虑如何在这样一个小矩阵中找出答案.我的策略是每次取四个角中最大值和最小值的点,这样可以每次删掉一行 ...

随机推荐

  1. python学习第6天

    id is ==  代码块 代码块的缓存机制 小数据池(不同代码块的缓存机制) 小数据池(驻留机制)总结 数据类型之间的转换 int bool str 三者转化是可以的. bool 可以与所有的数据类 ...

  2. 关于Dubbo和Spring异步注解@Async的冲突

    项目中难免会有异步处理的需求,像异步记录日志啦,异步发送邮件啦,而Dubbo又是现在主流的分布式框架,所有异步+Dubbo的组合是再所难免的 但博主是实践中发现Dubbo的服务并不能很好的跟Sprin ...

  3. 解决FTPClient上传文件为空,显示0字节

    JAVA使用FTPClient上传文件时总是为空,而使用FileZilla客户端时却不会. 后来查了下资料,FTP服务器有被动模式和主动模式.(具体查另外资料) 在JAVA中将FTPClient设置为 ...

  4. C# 封装微信的模板消息

    1.先新建一个类库,以方便以后移植到其他的项目上继续使用,如何新建类库就自己去百度了哈,这里就不描述了,若有不会的朋友请留言哈.标红了的都要注意下咯. 2.先看看WxTemplate这个类文件的代码 ...

  5. -bash: /opt/cslc/jdk1.8.0_144/bin/jps: /lib/ld-linux.so.2: bad ELF interpreter: 没有那个文件或目录

    yum install -y  glibc.i686 解决问题

  6. ajax控件无法使用 iis配置及web修改(转载)

    1.Web.config配置问题:将Web.config中的相关节配置成如下,然后重新编译你的程序:<httpHandlers><remove verb="*" ...

  7. Remove Duplicates from Sorted ListII

    给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中 没有重复出现 的数字. 示例 1: 输入: 1->2->3->3->4->4->5 输出: 1-&g ...

  8. django中数据库的配置及相关增删改查

    ORM ORM是什么?:(在django中,根据代码中的类自动生成数据库的表也叫--code first) ORM:Object Relational Mapping(关系对象映射) 类名对应---- ...

  9. linq2db.EntityFrameworkCore 介绍

    linq2db.EntityFrameworkCore 是一个ef core的插件,对linq语法的扩展 对复杂的sql都有很好的支持,他是基于linq2db (provided by LINQ To ...

  10. WIN 7 使用shutdown命令设置电脑自动关机

    使用组合键“WIN + R”,在弹出的对话窗“运行”中输入“cmd”,点击“确定”按钮或直接按回车键“Enter”.  设置电脑在一定时间后关机,比如60分钟,在弹出的对话框中,输入“shutdown ...