题目

小\(A\)和小\(B\)在一个长度为\(2n\)的数组上面博弈,初始时奇数位置为A,偶数位置为B

小\(A\)先手,第\(i\)次操作的人可以将\(i\)或者\(i+1\)位置的值反转(也可以不做任何操作)

\(n-1\)次操作结束后,小\(A\)得分为所有\(A\)位置的权值和,小\(B\)同理

每次会把一个权值改小,询问每次小A得到的和

$n \le 200000 $,权值为非负数

题解

  • 设\(f_{i,0/1}\)表示从\(i\)位置向后考虑,\(i\)位置有没有反转,当前操作的人和另一个人得分差值的最大值

    \[\begin{align}
    &\begin{cases}
    f_{i,0} \ &= \ max \{ s_i - f_{i+1,0} , s_i - f_{i+1,1} \} \\
    f_{i,1} \ &= \ max \{ s_i - f_{i+1,0} ,-s_i - f_{i+1,1} \} \\
    \end{cases}\\
    &设\Delta _i = f_{i,0} - f_{i,1} \\
    &由于s_i\ge 0 显然\Delta_i \ge 0\\
    &\begin{cases}
    f_{i,0} \ &= s_i - f_{i+1,1} \\
    f_{i,1} \ &= max \{ 2s_i - \Delta_{i+1} , 0 \} - s_i - f_{i+1,1} \\
    \Delta_i\ &= min \{ 2s_i , \Delta_{i+1} \}
    \end{cases}\\
    &\Delta_n=2s_n 维护 \Delta_i 也就是对2s_i 取后缀min \\
    &f_{1,0} = \sum_{i=1}^{n}(-1)^{i-1}s_i + \sum_{i=2}^{n} (-1)^i \Delta_{i} \\
    \end{align}
    \]

  • 维护后缀\(min\)值只有改小的话可以在线段树上先二分再修改,时间复杂度\(O(n \ log \ n)\)

  • 没有这个条件可以用线段树维护从前往后递增的单调栈

  • 具体来说每段区间维护最小值\(mn\)和区间答案\(sum\)

  • 考虑当前区间\(K\)的左右儿子为\(L,R\),左儿子\(L\)的左右儿子为\(l,r\)

    如果 $mn_{R} \lt mn_{r} $ ,右区间的贡献都为\(mn_R\),直接统计,并递归\(l\)

    如果 $ mn_R \ge mn_r $ ,记录$ add_K \(表示用\)K\(的左儿子的mn走右儿子的答案,直接统计\)add_K \(并递归\)r$

    时间复杂度:$O(n \log ^2n ) $

    #include<bits/stdc++.h>
    #define ll long long
    #define ls (k<<1)
    #define rs (k<<1|1) using namespace std; char gc(){
    static char*p1,*p2,s[1000000];
    if(p1==p2)p2=(p1=s)+fread(s,1,1000000,stdin);
    return(p1==p2)?EOF:*p1++;
    }
    int rd(){
    int x=0;char c=gc();
    while(c<'0'||c>'9')c=gc();
    while(c>='0'&&c<='9')x=(x<<1)+(x<<3)+c-'0',c=gc();
    return x;
    } const int N=200010;
    int n,m,s[N];
    ll tmp,Mn,mn[N<<2],sum[N<<2],add[N<<2],ans; ll sg(int l,int r,int x){return ((r-l)&1)?0:l&1?-x:x;}
    void mfy(int k,int l){mn[k]=s[l];sum[k]=l&1?-s[l]:s[l];}
    void cal(int k,int l,int r){
    if(l==r){tmp+=sg(l,r,min(Mn,mn[k]));return;}
    int mid=(l+r)>>1;
    if(Mn<mn[rs])tmp+=sg(mid+1,r,Mn),cal(ls,l,mid);
    else tmp+=add[k],cal(rs,mid+1,r);
    }
    void pushup(int k,int l,int r){
    mn[k]=min(mn[ls],mn[rs]);
    int mid=(l+r)>>1;
    tmp=0;Mn=mn[rs];
    cal(ls,l,mid);
    sum[k]=sum[rs]+(add[k]=tmp);
    }
    void build(int k,int l,int r){
    if(l==r){mfy(k,l);return;}
    int mid=(l+r)>>1;
    build(ls,l,mid);
    build(rs,mid+1,r);
    pushup(k,l,r);
    }
    void update(int k,int l,int r,int x){
    if(l==r){mfy(k,l);return;}
    int mid=(l+r)>>1;
    if(x<=mid)update(ls,l,mid,x);
    else update(rs,mid+1,r,x);
    pushup(k,l,r);
    }
    int main(){
    freopen("flip.in","r",stdin);
    freopen("flip.out","w",stdout);
    n=rd();
    for(int i=1;i<=n;++i){s[i]=rd();if(i&1)ans+=s[i];}
    build(1,2,n);
    printf("%lld\n",ans+sum[1]);
    m=rd();
    for(int i=1;i<=m;++i){
    int x=rd(),y=rd();
    if(x&1)ans-=s[x];
    s[x]-=y;if(x&1)ans+=s[x];
    if(x>1)update(1,2,n,x);
    printf("%lld\n",ans+sum[1]);
    }
    return 0;
    }

【JZOJ6223】【20190617】互膜的更多相关文章

  1. thusc2016游记&&滚粗记&&酱油记

    #include <cstdio> using namespace std; int main(){ puts("转载请注明出处:http://www.cnblogs.com/w ...

  2. NOIP2016呵呵记

    经过了一年的想象和臆测,经历了学长们的几次考试,通过老师的言语莫名感受过了所谓oi式压力之后,自己的考试也终于到来了. 考前的生活也没有想象中的那么充实,无非跟着神犇刷刷题,讨论算法,学点新技巧,然后 ...

  3. 出题人的RP值(牛客练习赛38--A题)(排序)

    链接:https://ac.nowcoder.com/acm/contest/358/A来源:牛客网 题目描述 众所周知,每个人都有自己的rp值(是个非负实数),膜别人可以从别人身上吸取rp值. 然而 ...

  4. Before NOIP 2018

    目录 总结 刷题 2018 - 9 - 24 2018 - 9 - 25 2018 - 9 - 26 2018 - 9 - 27 2018 - 9 - 28 2018 - 9 - 29 2018 - ...

  5. thusc2018酱油记

    day-1 打点行囊,从学校出发去火车站 day0 在火车上一觉醒来便快到了北京,直接前往了宾馆安置 下午报道,一脸向往地第一次走入清华园,感觉十分的梦幻,心里一直喃喃:"希望以后也能经常在 ...

  6. A.出题人的RP值

    链接:https://ac.nowcoder.com/acm/contest/358/A 题意: 众所周知,每个人都有自己的rp值(是个非负实数),膜别人可以从别人身上吸取rp值. 然而当你膜别人时, ...

  7. CSP-S 2019 游记

    目录 CSP-S 2019 游记 DAY -1 Day 0 Day 1 Day 2 后记 CSP-S 2019 游记 机房段子: zr(老师):yyx我看你最近不错哦(此人外号拳皇 yyx:运气好运气 ...

  8. 【杂文】NOIP2018 蒟蒻自闭记

    [杂文]NOIP2018 蒟蒻自闭记 都 \(9102\) 年了,谁还记得 \(2018\) 年的事啊 \(QAQ\) . 还有两个月就要去参加首届 \(CSP\) 了. 想着如果再不记下去年那些事儿 ...

  9. PHP实现中文简体字和繁体字互转

    function convert($str, $action='S'){ if($action != 'S' && $action != 'T'){ return $str; } $s ...

随机推荐

  1. webpack 打包出多个HTML文件,多个js文件,图片文件放置到指定文件夹中

    一.webpack.config.js简单代码 const HtmlWebpackPlugin = require('html-webpack-plugin'); module.exports = { ...

  2. The four Day 给出一个平衡字符串,将它分割成尽可能多的平衡字符串

    """ 在一个「平衡字符串」中,'L' 和 'R' 字符的数量是相同的. 给出一个平衡字符串 s,请你将它分割成尽可能多的平衡字符串. 返回可以通过分割得到的平衡字符串的 ...

  3. spring Boot 学习(三、Spring Boot与检索)

    一.检索我们的应用经常需要添加检索功能,开源的 ElasticSearch 是目前全文搜索引擎的 首选.他可以快速的存储.搜索和分析海量数据.Spring Boot通过整合Spring Data El ...

  4. 记录screen屏幕日志

    1.建立日志存放目录#mkdir /var/log/screen/ 2.修改配置文件,在末尾添加配置内容#vi /etc/screenrclogfile /var/log/screen/%t.log ...

  5. 【开发工具】- Idea.2018.02注册码激活

    1.从下面地址下载一个jar包,名称是  JetbrainsCrack-3.1-release-enc.jar 下载地址: 链接: https://pan.baidu.com/s/1VZjklI3qh ...

  6. JavaScript之控制标签属性

    var pic=document.getElementById('pic'); var obtn=document.getElementById('btn'); console.log(pic.get ...

  7. VLC架构及流程分析

    0x00 前置信息 VLC是一个非常庞大的工程,我从它的架构及流程入手进行分析,涉及到一些很细的概念先搁置一边,日后详细分析. 0x01 源码结构(Android Java相关的暂未分析) # bui ...

  8. 使用Blynk打造一款物联网产品

    前言 一直以来想自己打造一款物联网产品. 围绕这个话题写过一些文章: 一辆树莓派可编程小车的问题 基于树莓派的积木化编程解决方案 物联网相关开源项目整理 物联网.开源硬件与开源社区 之前在一辆树莓派可 ...

  9. Linux添加硬盘创建新的逻辑卷方式

    有同仁看了上文<Linux添加硬盘扩充已有分区存储空间方式>一文后,提出疑问,现在很多云服务器本来没有逻辑卷,添加数据盘后需要自行添加,如何处理? 此文将以某云服务器为例,详细进行解说. ...

  10. maven学习笔记五(仓库搭建,私服配置)

    实际项目中,我们往往都是多人开发,这个时候,假如一个项目有300多M.用的jar包有100多个.只要项目组来一个人就从中央仓库下载依赖的jar,这种下载一般都需要持续很久.而且中央仓库一般都是配置在外 ...