题目链接:Magician

题意:

给你一个长度为n的序列v,你需要对这个序列进行m次操作,操作一共有两种,输入格式为

type a b

1、如果type==0,你就需要输出[a,b]区间内的美丽序列中所有元素的和,要使得这个值尽可能大

2、如果type==1,你就需要把a位置的元素值改为b

区间[a,b]的美丽序列就是va,va+1...vb。你需要从中取出任意个元素,这些元素的位置必须是奇偶交替

例如给你一个序列1,2,3,4,5,6,7

你取出来的美丽序列就有可能使1,2,3,4,5,6,7或者1,4,5,6,7或者2,5,6,7

题解:

我们使用线段树,如果type==1的时候就修改就可以了。对于type==0的情况。我们可以维护四个值,分别是区间[a,b]内的美丽序列:

从一个偶数位置开始,到一个奇数位置截至,我们使用ab来代替

从一个奇数位置开始,到一个奇数位置截至,我们使用bb来代替

从一个偶数位置开始,到一个偶数位置截至,我们使用aa来代替

从一个奇数位置开始,到一个偶数位置截至,我们使用ba来代替

对于线段树上一个节点维护的值,我们把这个节点称为a,把它的左右节点称为b,c

a.ab=max(b.aa+c.bb,b.ab+c.ab);   如果左右子树合并
a.ab=max(a.ab,max(b.ab,c.ab)); 如果左右子树不合并

 

其他四个值的维护也是这样

代码:

#include <map>
#include <set>
#include <list>
#include <queue>
#include <deque>
#include <cmath>
#include <stack>
#include <vector>
#include <bitset>
#include <cstdio>
#include <string>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int maxn = 1e5+10;
const int INF = 0x3f3f3f3f;
const double PI = 3.1415926;
const long long N = 1000006;
const double eps = 1e-10;
typedef long long ll;
#define qmh(x) ask()
#define mt(A, B) memset(A, B, sizeof(A))
#define lson L, mid, rt<<1
#define rson mid + 1, R, rt<<1|1
#define ls rt<<1
#define rs rt<<1|1
#define SIS std::ios::sync_with_stdiget_mod_new(z-x)o(false), cin.tie(0), cout.tie(0)
#define pll pair<long long, long long>
#define lowbit(abcd) (abcd & (-abcd))
#define max(a, b) ((a > b) ? (a) : (b))
#define min(a, b) ((a < b) ? (a) : (b))
struct node
{
ll aa,bb,ab,ba;
void Clear()
{
aa=bb=ab=ba=-INF;
}
} tree[400009],result;
int arr[100009]; void Merge(node &a,node b,node c)
{
a.aa=max(b.ab+c.aa,b.aa+c.ba);
a.aa=max(a.aa,max(b.aa,c.aa));
a.bb=max(b.ba+c.bb,b.bb+c.ab);
a.bb=max(a.bb,max(b.bb,c.bb));
a.ab=max(b.aa+c.bb,b.ab+c.ab);
a.ab=max(a.ab,max(b.ab,c.ab));
a.ba=max(b.bb+c.aa,b.ba+c.ba);
a.ba=max(a.ba,max(b.ba,c.ba));
} void build(int rt,int L,int R)
{
if(L==R)
{
tree[rt].Clear();
if(L&1) tree[rt].aa=arr[L];
else tree[rt].bb=arr[L];
return ;
}
int mid=(L+R)>>1;
build(rt<<1,L,mid),build(rt<<1|1,mid+1,R);
Merge(tree[rt],tree[rt<<1],tree[rt<<1|1]);
} void update(int rt,int L,int R,int pos,int val)
{
if(L==R)
{
tree[rt].Clear();
if(L&1) tree[rt].aa=val;
else tree[rt].bb=val;
return ;
}
int mid=(L+R)>>1;
if(pos<=mid) update(rt<<1,L,mid,pos,val);
else update(rt<<1|1,mid+1,R,pos,val);
Merge(tree[rt],tree[rt<<1],tree[rt<<1|1]);
} void query(int rt,int L,int R,int LL,int RR)
{
if(L>=LL&&R<=RR)
{
Merge(result,result,tree[rt]);
return ;
}
int mid=(L+R)>>1;
if(mid>=LL) query(rt<<1,L,mid,LL,RR);
if(RR>mid) query(rt<<1|1,mid+1,R,LL,RR);
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
int n,m;
scanf("%d%d",&n,&m);
for(int i=1; i<=n; i++) scanf("%d",&arr[i]);
build(1,1,n);
while(m--)
{
int type,l,r;
scanf("%d%d%d",&type,&l,&r);
if(type==1) update(1,1,n,l,r);
else
{
result.Clear();
query(1,1,n,l,r);
printf("%lld\n",max(max(result.aa,result.bb),max(result.ab,result.ba)));
}
}
}
return 0;
}

hdu 5316 Magician 线段树维护最大值的更多相关文章

  1. hdu 5316 Magician 线段树

    链接:http://acm.hdu.edu.cn/showproblem.php? pid=5316 Magician Time Limit: 18000/9000 MS (Java/Others)  ...

  2. HDU.5692 Snacks ( DFS序 线段树维护最大值 )

    HDU.5692 Snacks ( DFS序 线段树维护最大值 ) 题意分析 给出一颗树,节点标号为0-n,每个节点有一定权值,并且规定0号为根节点.有两种操作:操作一为询问,给出一个节点x,求从0号 ...

  3. 线段树(维护最大值):HDU Billboard

    Billboard Time Limit: 20000/8000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  4. Codeforces 777E(离散化+dp+树状数组或线段树维护最大值)

    E. Hanoi Factory time limit per test 1 second memory limit per test 256 megabytes input standard inp ...

  5. HDU 6406 Taotao Picks Apples 线段树维护

    题意:给个T,T组数据: 每组给个n,m:n个数,m个操作: (对序列的操作是,一开始假设你手上东西是-INF,到i=1时拿起1,之后遍历,遇到比手头上的数量大的数时替换(拿到手的算拿走),问最后拿走 ...

  6. hdu 5068 线段树维护矩阵乘积

    http://acm.hdu.edu.cn/showproblem.php?pid=5068 题意给的略不清晰 m个询问:从i层去j层的方法数(求连段乘积)或者修改从x层y门和x+1层z门的状态反转( ...

  7. 51nod 1376【线段树维护区间最大值】

    引自:wonter巨巨的博客 定义 dp[i] := 以数字 i(不是下标 i)为结尾的最长上升长度 然后用线段树维护 dp[i]: 每个节点维护 2 个信息,一个是当前区间的最大上升长度,一个是最大 ...

  8. HDU 6155 Subsequence Count 线段树维护矩阵

    Subsequence Count Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 256000/256000 K (Java/Oth ...

  9. hdu 4037 Development Value(线段树维护数学公式)

    Development Value Time Limit: 5000/3000 MS (Java/Others)    Memory Limit: 65768/65768 K (Java/Others ...

随机推荐

  1. Flutter 基础组件:Widget简介

    概念 在Flutter中几乎所有的对象都是一个Widget.与原生开发中"控件"不同的是,Flutter中的Widget的概念更广泛,它不仅可以表示UI元素,也可以表示一些功能性的 ...

  2. 【ORA】ORA-16629解决办法

    数据库向保护模式报告不同的保护级别"警告消息. 首先查看主备库的保护模式和保护级别 select protection_mode,protection_level from v$databa ...

  3. LeetCode872. 叶子相似的树

    题目 1 class Solution { 2 public: 3 vector<int>ans1; 4 vector<int>ans2; 5 bool leafSimilar ...

  4. oracle视图添加hint

    /* Formatted on 2019/8/6 下午 02:51:21 (QP5 v5.163.1008.3004) */ SELECT DB FROM ( SELECT /*+ index(A.r ...

  5. STL_deque容器

    一.deque简介 deque是"double-ended queue"的缩写,和vector一样都是STL的容器,deque是双端数组,而vector是单端的. deque在接口 ...

  6. 在HTML中改变input标签中的内容

    在HTML中改变input标签的内容 1.使用js自带的方法: document.getElementById('roadName').value='武汉路';//通过标签选择器来选择标签,然后设置值 ...

  7. 容器化安装Mysql 8.0 并部署主从复制

    系统: Centos 7.4 数据库版本:8.0.20 两台机器做相同操作 安装Docker export VERSION=18.06 && curl -fsSL http://rai ...

  8. 进程的创建-multiprocessing

    multiprocessing模块就是跨平台版本的多进程模块,提供了一个Process类来代表一个进程对象,这个对象可以理解为是一个独立的进程,可以执行另外的事情 1. 2个while循环一起执行 # ...

  9. null调整为not null default xxx,不得不注意的坑

    最近碰到一个case,值得分享一下. 现象 一个DDL,将列的属性从null调整为not null default xxx, alter table slowtech.t1 modify name v ...

  10. 【笔记】学习markdown

    经过来自学长(姐?)的 嘲讽 善意提醒后,我才知道这个博客园好像 资瓷 markdown 于是我决定要认真学习markdown(绝不是因为洛谷题解又过不去了) 正常点: 由于没人教,我上网查了一下 一 ...