题目传送门:https://www.luogu.org/problemnew/show/P3514

题意:给出一个只有$1$和$2$的长度为$N$的数列,$M$次询问是否存在一段连续子区间和为$K$。$N,M \leq 10^6$


考虑存在答案为$Q$的区间会对其他答案有什么影响。然后能够发现:如果存在答案为$Q$的区间,就一定存在$\leq Q$且奇偶性相同的其他区间

证明:对于答案为$Q$的区间$(Q \geq 2)$,我们有以下方式递推出和为$Q - 2$的区间:

$a.num_l == 2,$新区间为$l+1,r$

$b.num_r == 2,$新区间为$l,r-1$

$c.num_l==num_r==1,$新区间为$l+1,r-1$

所以我们可以算出数列中和最大的和为奇数的区间与和为偶数的区间,并用它递推出所有答案区间,最后$O(1)$回答询问即可。

 #include<bits/stdc++.h>
 #define MAXN 1000010
 using namespace std;

 ][] , N , M;

 inline void culJi(int maxJi);
 inline void culOu(int maxOu);

 int main(){
     ios::sync_with_stdio();
     cin.tie();
     cout.tie();
     string s;
     cin >> N >> M >> s;
     ;
      ; i <= N ; i++)
         sum += (num[i] = s[i - ] ==  : );
     ans[sum][] = ;
     ans[sum][] = N;
     )
         culJi(sum);
     else
         culOu(sum);
      , q = N;
     )
         p++;
     )
         q--;
     if(p <= q){
          < N - q){
             sum -= (p -  << ) + ;
             ans[sum][] = p + ;
             ans[sum][] = N;
         }
         else{
             sum -= (N - q << ) + ;
             ans[sum][] = ;
             ans[sum][] = q - ;
         }
         )
             culJi(sum);
         else
             culOu(sum);
     }
     while(M--){
         int a;
         cin >> a;
         ])
             cout << ans[a][] << ] << '\n';
         else
             cout << "NIE\n";
     }
     ;
 }

 void culJi(int maxJi){
     ){
         ]] == ){
             ans[maxJi - ][] = ans[maxJi][] + ;
             ans[maxJi - ][] = ans[maxJi][];
         }
         else
             ]] == ){
                 ans[maxJi - ][] = ans[maxJi][];
                 ans[maxJi - ][] = ans[maxJi][] - ;
             }
             else{
                 ans[maxJi - ][] = ans[maxJi][] + ;
                 ans[maxJi - ][] = ans[maxJi][] - ;
             }
         maxJi -= ;
     }
 }

 void culOu(int maxOu){
     ){
         ]] == ){
             ans[maxOu - ][] = ans[maxOu][] + ;
             ans[maxOu - ][] = ans[maxOu][];
         }
         else
             ]] == ){
                 ans[maxOu - ][] = ans[maxOu][];
                 ans[maxOu - ][] = ans[maxOu][] - ;
             }
             else{
                 ans[maxOu - ][] = ans[maxOu][] + ;
                 ans[maxOu - ][] = ans[maxOu][] - ;
             }
         maxOu -= ;
     }
 }

Luogu3514 POI2011 Lollipop 递推、构造的更多相关文章

  1. hdu 1757 A Simple Math Problem (构造矩阵解决递推式问题)

    题意:有一个递推式f(x) 当 x < 10    f(x) = x.当 x >= 10  f(x) = a0 * f(x-1) + a1 * f(x-2) + a2 * f(x-3) + ...

  2. [ 9.24 ]CF每日一题系列—— 468A构造递推

    Description: 1 - n个数问你能否经过加减乘除这些运算n -1次的操作得到24 Solutrion: 一开始想暴力递推,发现n的范围太大直接否决,也否决了我的跑dfs,后来就像肯定有个递 ...

  3. HDU 1757 A Simple Math Problem 【矩阵经典7 构造矩阵递推式】

    任意门:http://acm.hdu.edu.cn/showproblem.php?pid=1757 A Simple Math Problem Time Limit: 3000/1000 MS (J ...

  4. HDU4565 So Easy! —— 共轭构造、二阶递推数列、矩阵快速幂

    题目链接:https://vjudge.net/problem/HDU-4565 So Easy! Time Limit: 2000/1000 MS (Java/Others)    Memory L ...

  5. poj2166 Heapsort[构造递推]

    构造一个n个点的大根堆让全部弹出时交换位置次数最多. 真心佩服我自己智商,这种题都做不出来 交换是在每次弹出堆顶,然后把堆尾元素置于堆顶,然后向下调整时产生的.玩样例可以发现似乎数字1每次都出现在堆最 ...

  6. 2018 焦作网络赛 L Poor God Water ( AC自动机构造矩阵、BM求线性递推、手动构造矩阵、矩阵快速幂 )

    题目链接 题意 : 实际上可以转化一下题意 要求求出用三个不同元素的字符集例如 { 'A' .'B' .'C' } 构造出长度为 n 且不包含 AAA.BBB CCC.ACB BCA.CAC CBC ...

  7. 利用Cayley-Hamilton theorem 优化矩阵线性递推

    平时有关线性递推的题,很多都可以利用矩阵乘法来解决. 时间复杂度一般是O(K3logn)因此对矩阵的规模限制比较大. 下面介绍一种利用利用Cayley-Hamilton theorem加速矩阵乘法的方 ...

  8. HDU 2842 (递推+矩阵快速幂)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2842 题目大意:棒子上套环.第i个环能拿下的条件是:第i-1个环在棒子上,前i-2个环不在棒子上.每个 ...

  9. P1067Warcraft III 守望者的烦恼(十大矩阵问题之七求递推式)

    https://vijos.org/p/1067 守望者-warden,长期在暗夜精灵的的首都艾萨琳内担任视察监狱的任务,监狱是成长条行的,守望者warden拥有一个技能名叫“闪烁”,这个技能可以把她 ...

随机推荐

  1. loadrunner 运行脚本-Run-time Settings-ContentCheck简单设置

    运行脚本-Run-time Settings-ContentCheck简单设置 by:授客 QQ:1033553122 ContentCheck的设置可用来让VuGen检测存在错误的站点页面.如果被测 ...

  2. Flutter 布局(八)- Stack、IndexedStack、GridView详解

    本文主要介绍Flutter布局中的Stack.IndexedStack.GridView控件,详细介绍了其布局行为以及使用场景,并对源码进行了分析. 1. Stack A widget that po ...

  3. 导入另一个 Git库到现有的Git库并保留提交记录

    在要合并到的目标git仓库,执行 "git pull  远程分支地址/本地git仓库根目录"

  4. Anaconda3 错误集合

    1. An error ocurred while starting the kernel 答:个人猜测有可能是配置文件出现问题,于是采用如下解决方法: 在终端中输入spyder --reset,重置 ...

  5. java面试题之----spring MVC的原理和MVC

    1.什么是mvc? 1.1原始比较初级的设计模式: 1.2 MVC设计模式 2MVC设计模式的优势与核心在于其能解耦和: 传统的设计模式相当于是一个串联的设计,只要其中一个环节出了问题便会使下一环节中 ...

  6. windows server服务器上mysql远程连接失败的坑

    windows server服务器上mysql远程连接失败的坑 背景:趁这阿里云活动,和朋友合伙买了个服务器,最坑的是没想到他买的是windows Server的,反正便宜,将就着用吧,自己装好了wa ...

  7. <!DOCTYPE>标签与table高度100% (转)

    <!DOCTYPE>标签可声明三种DTD类型,分别表示严格版本.过渡版本以及基于框架的 HTML 文档. 三种HTML文档类型: HTML 4.01 规定了三种文档类型:Strict.Tr ...

  8. <20190106>千兆 小型局域网传输速率不达标问题解决

    故障描述: 三层交换机下挂了 个一层交换机, 全部交换终端包括路由器传输界面意确认全是千兆设备, 其中NAS端到 主机1 的传输速度只有100Mb, 观察主机1 的网络配置,确实连接速度是 100Mb ...

  9. 实时监听input输入的变化(兼容主流浏览器)【转】

    遇到如此需求,首先想到的是change事件,但用过change的都知道只有在input失去焦点时才会触发,并不能满足实时监测的需求,比如监测用户输入字符数. 在经过查阅一番资料后,欣慰的发现firef ...

  10. SALALchemy Session与scoped_session的源码分析

    我们发现Session与scoped_session都有一些方法: 但是scoped_session的源码里面没有设置这些方法让我们从源码里去窥探下源码在哪里设置了这些方法: Session里面的方法 ...