2288: 【POJ Challenge】生日礼物

Time Limit: 10 Sec  Memory Limit: 128 MB
Submit: 382  Solved: 111
[Submit][Status][Discuss]

Description

ftiasch 18岁生日的时候,lqp18_31给她看了一个神奇的序列 A1A2, ..., AN. 她被允许选择不超过 M 个连续的部分作为自己的生日礼物。

自然地,ftiasch想要知道选择元素之和的最大值。你能帮助她吗?

 

Input

第1行,两个整数 N (1 ≤ N ≤ 105) 和 M (0 ≤ M ≤ 105), 序列的长度和可以选择的部分。

第2行, N 个整数 A1A2, ..., AN (0 ≤ |Ai| ≤ 104), 序列。

Output

一个整数,最大的和。

Sample Input

5 2
2 -3 2 -1 2

Sample Output

5

  先把相邻同号元素合并。
  如果能够全选正数就全选。。
  把所有数的绝对值入堆选前(正数个数-可选最大集合数个).
  选正数的意义-->不选该数
  选负数-->合并两边的正数
  每次减掉堆顶元素的fabs即可。
  和1150差不多的堆+链表
 #include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<queue> #define maxn 100001 inline int in()
{
int x=,f=;char ch=getchar();
while((ch<''||ch>'')&&ch!='-')ch=getchar();
if(ch=='-')f=-,ch=getchar();
while(ch>=''&&ch<='')x=x*+ch-'',ch=getchar();
return f*x;
} struct node{
int x,c,ac;
bool operator<(const node &A)const{
return ac>A.ac;
}
}; using namespace std; priority_queue<node>q; int n,k,a[maxn*],sum=,pre[maxn*],next[maxn*],nowa[maxn*],tot=,ss=; bool vis[maxn*]; void solve()
{
int size=tot+;
for(int i=;i<=tot;i++)q.push((node){i,nowa[i],fabs(nowa[i])});
for(int i=;i<=ss;i++)
{
node Top=q.top();q.pop();
while(vis[Top.x])Top=q.top(),q.pop();
if(!pre[Top.x])
{
if(Top.c<){i--;}
else{sum-=Top.ac;}
vis[Top.x]=;
pre[next[Top.x]]=;
continue;
}
else if(next[Top.x]==tot+)
{
if(Top.c<){i--;}
else{sum-=Top.ac;}
vis[Top.x]=;
next[pre[Top.x]]=tot+;
continue;
}
node New;
sum-=Top.ac;
New.c=nowa[pre[Top.x]]+nowa[next[Top.x]]+Top.c;
New.x=++size;
nowa[size]=New.c;
next[New.x]=next[next[Top.x]],pre[next[New.x]]=New.x;
pre[New.x]=pre[pre[Top.x]],next[pre[New.x]]=New.x;
vis[Top.x]=vis[pre[Top.x]]=vis[next[Top.x]]=;
New.ac=fabs(New.c);
q.push(New);
}
} void Pre()
{
tot=;
for(int i=;i<=n;i++)
{
if(!a[i])continue;
else if(!nowa[tot])nowa[tot]=a[i];
else{
if(nowa[tot]>&&a[i]>)nowa[tot]+=a[i];
else if(nowa[tot]<&&a[i]<)nowa[tot]+=a[i];
else nowa[++tot]=a[i];
}
}
for(int i=;i<=tot;i++)next[i]=i+,pre[i]=i-;
next[]=,pre[tot+]=tot;
} int main()
{
n=in();k=in();
for(int i=;i<=n;i++)a[i]=in();
Pre();
for(int i=;i<=tot;i++)if(nowa[i]>)ss++,sum+=nowa[i];
if(ss<=k){printf("%d",sum);return ;}
ss-=k;
solve();
printf("%d",sum);
return ;
}
 

【链表】BZOJ 2288: 【POJ Challenge】生日礼物的更多相关文章

  1. BZOJ3502PA2012Tanie linie&BZOJ2288[POJ Challenge]生日礼物——模拟费用流+链表+堆

    题目描述 n个数字,求不相交的总和最大的最多k个连续子序列. 1<= k<= N<= 1000000. 输入 输出 样例输入 5 2 7 -3 4 -9 5 样例输出 13   根据 ...

  2. BZOJ2288:[POJ Challenge]生日礼物——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=2288 ftiasch 18岁生日的时候,lqp18_31给她看了一个神奇的序列 A1, A2, . ...

  3. BZOJ.2287.[POJ Challenge]消失之物(退背包)

    BZOJ 洛谷 退背包.和原DP的递推一样,再减去一次递推就行了. f[i][j] = f[i-1][j-w[i]] + f[i-1][j] f[i-1][j] = f[i][j] - f[i-1][ ...

  4. BZOJ2288:[POJ Challenge]生日礼物

    浅谈堆:https://www.cnblogs.com/AKMer/p/10284629.html 题目传送门:https://lydsy.com/JudgeOnline/problem.php?id ...

  5. [bzoj2288][POJ Challenge]生日礼物

    用堆维护双向链表来贪心... 数据范围显然不容许O(nm)的傻逼dp>_<..而且dp光是状态就n*m个了..显然没法优化 大概就会想到贪心乱搞了吧...一开始想贪心地通过几段小的负数把正 ...

  6. BZOJ 2295: [POJ Challenge]我爱你啊

    由于是子序列,那么难度就在于读入 #include<cstdio> #include<algorithm> #include<cstring> using name ...

  7. bzoj 2288 【POJ Challenge】生日礼物 双向链表+堆优化

    2288: [POJ Challenge]生日礼物 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1003  Solved: 317[Submit][ ...

  8. 【BZOJ 2288】 2288: 【POJ Challenge】生日礼物 (贪心+优先队列+双向链表)

    2288: [POJ Challenge]生日礼物 Description ftiasch 18岁生日的时候,lqp18_31给她看了一个神奇的序列 A1, A2, ..., AN. 她被允许选择不超 ...

  9. 2288.【POJ Challenge】生日礼物 链表+堆+贪心

    BZOJ2288 [POJ Challenge]生日礼物 题意: 给一个长度为\(n\)的数组,最多可以选\(m\)个连续段,问选取的最大值是多少 题解: 先把连续的符号相同的值合并,头和尾的负数去掉 ...

随机推荐

  1. 在win下面使用cdt+cygwin+cmake

    在cygwin终端下面, cmake -G"Eclipse CDT4 - Unix Makefiles" -D CMAKE_BUILD_TYPE=Debug 当收获警告 Could ...

  2. iMAC——查看开机关机时间

    每次下班都记不好早上几点打的卡,你是不是也经常有这样的情况:  那就用以下的代码考到Mac电脑的终端中,回车: mac终端输入上面命令行 查看开机时间: last | grep reboot 查看关机 ...

  3. windows API 核心编程学习心得

    一.错误处理 在内部,当windows函数检测到错误时,它会使用“线程本地存储区”的机制将相应的错误代码与“主调线程”关联到一起. winError.h 一般在C:\Program Files\Mic ...

  4. es5 和 es6 class

    // ES5 function User(name,age) { this.name = name; this.age = age; } // 静态方法 User.getClassName = fun ...

  5. css3学习笔记之多列

    CSS3 创建多列 column-count 属性指定了需要分割的列数. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 <!D ...

  6. Java-IO 输入输出流详解

    一.文件的编码               开发时一定要注意项目默认的编码!!!!!!!!               文件操作的时候一定要记得关闭!!!!!!!!        ASCII:美国标准 ...

  7. java web中Jdbc访问数据库步骤通俗解释(吃饭),与MVC的通俗解释(做饭)

    一.Jdbc访问数据库步骤通俗解释(吃饭) 1)加载驱动 Class.forName(“com.microsoft.jdbc.sqlserver.SQLServer”); 2) 与数据库建立连接 Co ...

  8. sed- 文本流编辑器

    sed                    [选项]                                             [参数] -n   被操作行打印输出           ...

  9. 找回mysql数据库密码

    前提条件:你需要有数据库服务器的权限 1:修改my.ini配置文件 Mysqld:其中的d代表什么? Deamon后台运行的服务程序,增加一行跳过权限验证 2:停止mysql服务运行 3:启动mysq ...

  10. ecshop中无限处理分类

    数据库表记录结构 <?php $sql = "SELECT c.cat_id, c.cat_name, c.measure_unit, c.parent_id, c.is_show, ...