块状链表 bzoj 3343教主的魔法
//块状链表
//分块排序,然后每次查找时在暴力查找头和尾两个块。
//中间那些块,因为有序所以只需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;
}
最新文章
- IOS内存管理学习笔记
- PS网页设计教程XXX——在PS中创建一个漫画书主题网页布局
- Webservice 调用方式整理
- h2database源码浅析:SQL语句的执行
- Android App 内存泄漏Handler
- Java中双向链表的代码实现
- python内置方法总结
- java中&;和&;&;的区别 位运算
- 元素定位之Ui-Automator-Viewer的使用
- Python面向对象2:类与对象的成员分析及self
- java面试题大全-基础方面 答案自己写
- Java ThreadLocal的使用
- linux命令学习之:curl
- Django项目之cookie+session
- pandas简单应用
- Laravel 的 Events(事件) 及 Observers(观察者)
- 试读《基于MVC的JavaScript Web富应用开发》— 不一样的JavaScript
- 开始第一个Android应用程序
- poj做的题
- 2017/11/21 Leetcode 日记
热门文章
- MySQL数据安全
- The best way to learn a programming language
- Oracle和SQL Server 用当前日期减去 &#39;0001-01-01&#39; 得出的天数不一致,相差2天,谁知道原因?
- Dockerfile编写,以及设置一个自启动脚本
- 在论坛中出现的比较难的sql问题:21(递归问题 检索某个节点下所有叶子节点)
- RuntimeError: Model class users.models.UserProfile doesn&#39;t declare an explicit app_label and isn&#39;t in an application in INSTALLED_APPS.
- axios 发 post 请求,后端接收不到参数的解决方案(转载)
- 本地安装SQL Server 2017 Express和Microsoft SQL Server Management Studio 18.1
- sql 防注入(更新问题)
- SEO基础知识