//块状链表
//分块排序,然后每次查找时在暴力查找头和尾两个块。
//中间那些块,因为有序所以只需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;
}

最新文章

  1. IOS内存管理学习笔记
  2. PS网页设计教程XXX——在PS中创建一个漫画书主题网页布局
  3. Webservice 调用方式整理
  4. h2database源码浅析:SQL语句的执行
  5. Android App 内存泄漏Handler
  6. Java中双向链表的代码实现
  7. python内置方法总结
  8. java中&amp;和&amp;&amp;的区别 位运算
  9. 元素定位之Ui-Automator-Viewer的使用
  10. Python面向对象2:类与对象的成员分析及self
  11. java面试题大全-基础方面 答案自己写
  12. Java ThreadLocal的使用
  13. linux命令学习之:curl
  14. Django项目之cookie+session
  15. pandas简单应用
  16. Laravel 的 Events(事件) 及 Observers(观察者)
  17. 试读《基于MVC的JavaScript Web富应用开发》— 不一样的JavaScript
  18. 开始第一个Android应用程序
  19. poj做的题
  20. 2017/11/21 Leetcode 日记

热门文章

  1. MySQL数据安全
  2. The best way to learn a programming language
  3. Oracle和SQL Server 用当前日期减去 &#39;0001-01-01&#39; 得出的天数不一致,相差2天,谁知道原因?
  4. Dockerfile编写,以及设置一个自启动脚本
  5. 在论坛中出现的比较难的sql问题:21(递归问题 检索某个节点下所有叶子节点)
  6. RuntimeError: Model class users.models.UserProfile doesn&#39;t declare an explicit app_label and isn&#39;t in an application in INSTALLED_APPS.
  7. axios 发 post 请求,后端接收不到参数的解决方案(转载)
  8. 本地安装SQL Server 2017 Express和Microsoft SQL Server Management Studio 18.1
  9. sql 防注入(更新问题)
  10. SEO基础知识