盲猜dp系列。。。

题意:给定序列,选了i就不能选与i相邻的两个,求最大值,带修改

蒟蒻在考场上10min打完以为只有两种情况的错解。。。居然能骗一点分。。。

先讲下当时的思路吧。

f【i】【0/1】表示第i台选不选的挤奶最大值,两个转移,水得不行。

考完之后在大佬的点播下才明白,这是一个类似独立集的东西。

但是这个数据范围绝对不是让我们跑最大独立集的,毕竟还要修改233。。。

solution:

求和....单点修改...最大值....貌似能想到些什么.....

可爱的线段树。。(一点都不可爱)

毕竟序列长不变,只要单点修改就行了。

建一棵线段树,里面存f1,f2,f3,f4,l,r;

// f1 表示两端都选 // f2 表示左选右不选 // f3 表示左不选右选 // f4 表示左右都不选

然后转移就比较长,其它也没有什么(应该能看明白就懒得写注释了)

void update(ll k)
{
t[k].f1=max(t[lch(k)].f1+t[rch(k)].f3,t[lch(k)].f2+max(t[rch(k)].f1,t[rch(k)].f3));
t[k].f2=max(t[lch(k)].f1+t[rch(k)].f4,t[lch(k)].f2+max(t[rch(k)].f2,t[rch(k)].f4));
t[k].f3=max(t[lch(k)].f3+t[rch(k)].f3,t[lch(k)].f4+max(t[rch(k)].f1,t[rch(k)].f3));
t[k].f4=max(t[lch(k)].f3+t[rch(k)].f4,t[lch(k)].f4+max(t[rch(k)].f2,t[rch(k)].f4));
}

然后就是线段树的事了

代码:

#include<bits/stdc++.h>
#define lch(x) x<<1
#define rch(x) x<<1|1
#define ll long long
using namespace std;
const ll maxn=1e6+;
ll a[maxn];
ll n,d;
ll ans;
struct tree
{
ll f1,f2,f3,f4;
ll l,r;
}t[maxn];
ll p,v;
void update(ll k)
{
t[k].f1=max(t[lch(k)].f1+t[rch(k)].f3,t[lch(k)].f2+max(t[rch(k)].f1,t[rch(k)].f3));
t[k].f2=max(t[lch(k)].f1+t[rch(k)].f4,t[lch(k)].f2+max(t[rch(k)].f2,t[rch(k)].f4));
t[k].f3=max(t[lch(k)].f3+t[rch(k)].f3,t[lch(k)].f4+max(t[rch(k)].f1,t[rch(k)].f3));
t[k].f4=max(t[lch(k)].f3+t[rch(k)].f4,t[lch(k)].f4+max(t[rch(k)].f2,t[rch(k)].f4));
}
void build(ll l,ll r,ll p)
{
t[p].l=l;
t[p].r=r;
if(l==r)
{
t[p].f1=a[l];
return;
}
ll mid=l+r>>;
build(l,mid,p<<);
build(mid+,r,p<<|);
update(p);
}
void change(ll k)
{
if(t[k].l==t[k].r)
{
t[k].f1=v;
return;
}
ll mid=(t[k].l+t[k].r)>>;
if(p<=mid)change(k<<);
else change(k<<|);
update(k);
}
int main()
{
scanf("%lld%lld",&n,&d);
for(ll i=;i<=n;i++)
{
scanf("%lld",&a[i]);
}
build(,n,);
for(ll i=;i<=d;i++)
{
scanf("%lld%lld",&p,&v);
change();
ans+=max(max(t[].f1,t[].f2),max(t[].f3,t[].f4));
}
printf("%lld",ans);
return ;
}

(完)

最新文章

  1. 解决pydev报unsolved import的问题
  2. StringIO学习
  3. WebService 调用
  4. Struts2文件上传(基于表单的文件上传)
  5. PHP中is_numeric函数十六进制绕过0day
  6. 使用VIRTUALBOX安装ANDROID系统 | 图文教程 | 相关设置
  7. js——页面回到顶部
  8. CentOS 常用命令大全(2)
  9. Struts2 Annotation 默认返回Tiles2布局
  10. LSJ_NHibernate第二章 ManagerPage
  11. .NET2.0下的对象生成JSON数据
  12. Html 内嵌 选择器属性 Dom操作 JavaScript 事件
  13. Spring Cloud 组件 —— feign
  14. spring-boot集成activiti的model遇到问题汇总
  15. codeforces707C
  16. Zookeeper —— 初识
  17. 6-4 破碎的键盘 uva11988
  18. git服务器搭建全程
  19. FZU - 2150 Fire Game bfs+双起点枚举
  20. ms cms

热门文章

  1. 问题TypeError: __init__() takes 1 positional argument but 2 were given解决方案
  2. Unknown column &#39;user_id&#39; in &#39;where clause&#39;
  3. javascript DOM节点
  4. markdown下载、安装、破解、汉化与常用语法
  5. 爬虫 xpath
  6. C#学习--SQL server数据库基本操作(连接、增、删、改、查)封装
  7. [JZOJ5773]【NOIP2008模拟】简单数学题
  8. php好在哪?
  9. 微信小程序单选/多选框样式重新
  10. ESP8266开发之旅 基础篇⑤ ESP8266 SPI通信和I2C通信