//块状链表
//分块排序,然后每次查找时在暴力查找头和尾两个块。
//中间那些块,因为有序所以只需2分查找即可。我用的是lower_pound();
//插入是,也是头和尾暴力插入,中间那些加到一个累计里即可。
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<iostream>
using namespace std;
int a[1000005],b[1000005],lei[1000005],dian[1000005],l[1000005],r[1000005];
int n,m,len,len1;
char ch[2];
void jian(int a1)
{
 l[a1]=(a1-1)*len1+1;
 r[a1]=min(a1*len1,n);
 for(int i=l[a1];i<=r[a1];i++)
   b[i]=a[i];
 sort(b+l[a1],b+r[a1]+1);
}
void jia(int a1,int a2,int a3)
{
 if(dian[a1]==dian[a2])
   {
    for(int i=a1;i<=a2;i++)
      a[i]+=a3;
    jian(dian[a1]);
    return;
   }
 for(int i=a1;i<=r[dian[a1]];i++)
    a[i]+=a3;
 for(int i=l[dian[a2]];i<=a2;i++)
    a[i]+=a3;
 for(int i=dian[a1]+1;i<dian[a2];i++)
    lei[i]+=a3;
 jian(dian[a1]);
 jian(dian[a2]);
 return;
}
int zhao(int a1,int a2,int a3)
{
 int sum=0,s;
 if(dian[a1]==dian[a2])
   {
    for(int i=a1;i<=a2;i++)
      if(a[i]+lei[dian[a1]]>=a3)
        sum++;
    return sum;
   }
 for(int i=a1;i<=r[dian[a1]];i++)
    if(a[i]+lei[dian[a1]]>=a3)
      sum++;
 for(int i=l[dian[a2]];i<=a2;i++)
    if(a[i]+lei[dian[a2]]>=a3)
      sum++;
 for(int i=dian[a1]+1;i<dian[a2];i++)
   {
     s=lower_bound(b+l[i],b+r[i]+1,a3-lei[i])-b;
     sum+=r[i]+1-s;
      }
 return sum;
}
int main()
{
 scanf("%d%d",&n,&m);
 for(int i=1;i<=n;i++)
   scanf("%d",&a[i]);
 len1=floor(sqrt(n));
 len=n/len1;
 if(n%len1)
   len++;
 for(int i=1;i<=len;i++)
   jian(i);
 for(int i=1;i<=n;i++)
   dian[i]=(i-1)/len1+1;
 for(int i=0;i<m;i++)
   {
    int a1,a2,a3;
    scanf("%s%d%d%d",ch,&a1,&a2,&a3);
    if(ch[0]=='A')
      printf("%d\n",zhao(a1,a2,a3));
    else
      jia(a1,a2,a3);
   }
 return 0;
}

块状链表 bzoj 3343教主的魔法的更多相关文章

  1. BZOJ 3343: 教主的魔法(分块+二分查找)

    BZOJ 3343: 教主的魔法(分块+二分查找) 3343: 教主的魔法 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1172  Solved:  ...

  2. BZOJ 3343: 教主的魔法 [分块]【学习笔记】

    3343: 教主的魔法 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1172  Solved: 526[Submit][Status][Discus ...

  3. Bzoj 3343: 教主的魔法 分块,二分

    3343: 教主的魔法 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 821  Solved: 364[Submit][Status][Discuss ...

  4. Bzoj 3343: 教主的魔法(分块+二分答案)

    3343: 教主的魔法 Time Limit: 10 Sec Memory Limit: 256 MB Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息 ...

  5. BZOJ——3343: 教主的魔法 || 洛谷—— P2801 教主的魔法

    http://www.lydsy.com/JudgeOnline/problem.php?id=3343  ||  https://www.luogu.org/problem/show?pid=280 ...

  6. BZOJ 3343教主的魔法

    Description 教主最近学会了一种神奇的魔法,能够使人长高.于是他准备演示给XMYZ信息组每个英雄看.于是N个英雄们又一次聚集在了一起,这次他们排成了一列,被编号为1.2.…….N. 每个人的 ...

  7. bzoj 3343: 教主的魔法

    Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 924  Solved: 402[Submit][Status][Discuss] Descriptio ...

  8. bzoj 3343 教主的魔法 分块

    修改直接对整块打标记,两边暴力. 查询需要保证每个整块有序,所以在修改时排序就好啦 #include<cstdio> #include<cstring> #include< ...

  9. [bzoj] 3343 教主的魔法 || 带修改分块

    原题 长度为n的序列,有两种操作: 1.[l,r]区间每个数+w 2.询问[l,r]区间有多少个数>c 记录lazy数组即可. #include<cstdio> #include&l ...

随机推荐

  1. WebApi如何传递参数

    一 概述 一般地,我们在研究一个问题时,常规的思路是为该问题建模:我们在研究相似问题时,常规思路是找出这些问题的共性和异性.基于该思路,我们如何研究WebApi参数传递问题呢? 首先,从参数本身来说, ...

  2. JNI创建共享内存导致JVM terminated的问题解决(segfault,shared memory,内存越界,内存泄漏,共享内存)

    此问题研究了将近一个月,最终发现由于JNI不支持C中创建共享内存而导致虚拟机无法识别这块共享内存,造成内存冲突,最终虚拟机崩溃. 注意:JNI的C部分所使用的内存也是由JVM创建并管理的,所以C创建了 ...

  3. jmeter接口测试中的用例数据分离

    用jmeter做接口测试的话,一个jmx文件就可以是一个用例,而用例的设计多数还是等价类.边界值等方法.用例越来越多的时候,维护比较麻烦,所以可以把用例的数据存在csv文件中,然后通过组件(CSV D ...

  4. html启动本地.exe文件

    之前没有了解这个内容,还是一个小伙伴在面试中遇到的一个题目,感觉挺有意思就研究了一下这个东西到底是怎么用的.搜了一下解决方法,是添加注册表,自己运行了可以使用 第一步:首先打开注册表,方法是 win+ ...

  5. metasploit情报收集

    1.msf连接数据库 service postgresql start(postgresql默认用户名scott,密码tiger) msf > db_connect 用户名:密码@127.0.0 ...

  6. nginx热加载、热升级、回滚

    修改完配置文件后使用 nginx -s reload 命令进行热加载 编译好新的 nginx 二进制文件后,运行nginx 开启nginx服务,然后使用 kill -USR2 新的nginx_mast ...

  7. web前端如何优化自己的代码

    前端的性能优化主要分为三部分: HTML优化 避免 HTML 中书写 CSS 代码,因为这样难以维护. 使用Viewport加速页面的渲染. 使用语义化标签,减少 CSS 代码,增加可读性和 SEO. ...

  8. vbox 网络配置

    vagrant主机与虚拟机通讯网络有两种模式: config.vm.network "private_network", ip: "192.168.33.10" ...

  9. nginx 请求限制和访问控制

    请求限制 限制主要有两种类型: 连接频率限制: limit_conn_module 请求频率限制: limit_req_module HTTP协议的连接与请求 HTTP协议是基于TCP的,如果要完成一 ...

  10. Windows Server 2008更改SID

    参考:Windows Server 2012 克隆修改SID 前言 克隆(软克隆,硬克隆)虚拟机后,虚拟机不光名称一样,IP一样(设置静态IP情况下),连SID也一样 什么是SID SID 安全标识符 ...