Description

berber走进机房,边敲门边喊:“我是哔哔”
CRAZY转过头:“我警告你,哔哔刚刚来过!”
“呵呵呵呵……”
这时,哔哔站了起来,环顾四周:“你们笑什么?……”
巧了,发出笑声的人都排成了一排,每个人刚开始发出的笑声值为a[i]的笑声。但是有些笑声哔哔是听不出来的,他只听得出笑声值只包含2和3的数字,比如说什么2333。
但是同学们还是很会秀操作的。对于操作add  l r x表示l到r的同学的笑声值同时加上x。数据保证操作完的x在2*10^4以内。
但是,哔哔还是很想知道哪些人在笑。对于count l r表示询问l到r的同学中有多少个笑声值是哔哔听得出来的(就是只由2和3组成)。
哔哔是很忙的,他需要坐在旁边的你来帮他完成这个问题。
 

Input

第一行两个整数分别为n,m表示同学的数目和操作数。第二行n个整数a[i]表示同学一开始的笑声值。接下来m行表示操作数,描述如上。

Output

按照题目输出答案。
 

Sample Input

3 6
2 3 4
count 1 3
count 1 2
add 1 3 2
count 1 3
add 2 3 3
count 1 3

Sample Output

2
2
0
0
 

Data Constraint

对于20%的数据n,m≤2000
对于另外30%的数据n,m≤50000
对于另外50%的数据n,m≤300000
本题时限3s

题意就是区间修改和区间查询,其中查询是某区间内不含2,3以外的数的个数。

区间修改我们可以用线段树来维护,但问题就在查询。线段树查询并不支持直接查询题目要求的数的个数,我们虽然可以一个一个检查,但除法取模运算相比也比较慢,每次查询的nlogn复杂度也接受不了。

直接维护不好做,我们可以尝试改变一下线段树维护的信息。

我们注意到题目给出的a[i]的最大值不会超过20000,在20000内符合题目的233数一共也只有31个,我们可以预处理这些,然后维护每个数a[i]与这些数相差最小的且比a[i]大的数的差值,很明显,当差值为0的时候就说明它是个233数,如果差值小于0,我们就要找下一个比它大且相差最小的233数,作差比较,由于每个数最多被修改31次,所以复杂度为O(31mlogn)

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<ctime>
#define N 1600000
using namespace std;
struct data{
int cnt,min,mark;
}tree[N];
int f[]={,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,};
int n,m,voi[N/],x,y,z,top[N/];
char str[];
void build(int root,int l,int r){
tree[root].mark=;
if (l==r){
while (f[top[l]]<voi[l]) top[l]++;
tree[root].min=f[top[l]]-voi[l];
if (tree[root].min==) tree[root].cnt=;
return;
}
int mid=(l+r)>>;
build(root<<,l,mid);
build(root<<|,mid+,r);
tree[root].min=min(tree[root<<].min,tree[root<<|].min);
tree[root].cnt=tree[root<<].cnt+tree[root<<|].cnt;
}
void pushdown(int root,int l,int r){
if (tree[root].mark){
tree[root<<].mark+=tree[root].mark;
tree[root<<|].mark+=tree[root].mark;
tree[root<<].min+=tree[root].mark;
tree[root<<|].min+=tree[root].mark;
tree[root].mark=;
}
return;
}
void updata(int root,int l,int r){
if (tree[root].min>) return;
if (l==r){
if (tree[root].min<){
voi[l]-=tree[root].mark;
tree[root].mark=;
while (f[top[l]]<voi[l]) top[l]++;
tree[root].min=f[top[l]]-voi[l];
}
if (tree[root].min==) tree[root].cnt=;
else tree[root].cnt=;
return;
}
pushdown(root,l,r);
int mid=(l+r)>>;
updata(root<<,l,mid);
updata(root<<|,mid+,r);
tree[root].min=min(tree[root<<].min,tree[root<<|].min);
tree[root].cnt=tree[root<<].cnt+tree[root<<|].cnt;
}
void add(int root,int l,int r,int x,int y,int z){
if ((x<=l)&&(y>=r)){
tree[root].min+=z;
tree[root].mark+=z;
if (tree[root].min<=)
updata(root,l,r);
return;
}
pushdown(root,l,r);
int mid=(l+r)>>;
if (x<=mid) add(root<<,l,mid,x,y,z);
if (y>mid) add(root<<|,mid+,r,x,y,z);
tree[root].min=min(tree[root<<].min,tree[root<<|].min);
tree[root].cnt=tree[root<<].cnt+tree[root<<|].cnt;
}
int count(int root,int l,int r,int x,int y){
if ((x<=l)&&(y>=r)) return tree[root].cnt;
int ans=;
int mid=(l+r)>>;
if (x<=mid) ans+=count(root<<,l,mid,x,y);
if (y>mid) ans+=count(root<<|,mid+,r,x,y);
return ans;
}
int main(){
scanf("%d%d",&n,&m);
for (int i=;i<=n;i++)
scanf("%d",&voi[i]);
build(,,n);
while (m--){
scanf("%s",str);
if (str[]=='c'){
scanf("%d%d",&x,&y);
printf("%d\n",count(,,n,x,y));
}
else{
scanf("%d%d%d",&x,&y,&z);
add(,,n,x,y,-z);
}
}
return ;
}

神奇的代码

(cin只读入字符串还是巨慢QAQ改成scanf瞬间从3000ms+变成300ms+)

JZOJ.5289【NOIP2017模拟8.17】偷笑的更多相关文章

  1. JZOJ.5288【NOIP2017模拟8.17】球场大佬

    Description       每天下午,古猴都会去打羽毛球.但是古猴实在是太强了,他必须要到一些比较强的场去打.但是每个羽毛球场都有许多的人排着队,每次都只能上四个人,每个人都有自己的能力值,然 ...

  2. [jzoj 5343] [NOIP2017模拟9.3A组] 健美猫 解题报告 (差分)

    题目链接: http://172.16.0.132/senior/#main/show/5343 题目: 题解: 记旋转i次之后的答案为$ans_i$,分别考虑每个元素对ans数组的贡献 若$s_i& ...

  3. 【NOIP2017提高A组模拟9.17】信仰是为了虚无之人

    [NOIP2017提高A组模拟9.17]信仰是为了虚无之人 Description Input Output Sample Input 3 3 0 1 1 7 1 1 6 1 3 2 Sample O ...

  4. 【NOIP2017提高A组模拟9.17】猫

    [NOIP2017提高A组模拟9.17]猫 题目 Description 信息组最近猫成灾了! 隔壁物理组也拿猫没办法. 信息组组长只好去请神刀手来帮他们消灭猫.信息组现在共有n 只猫(n 为正整数) ...

  5. 【NOIP2017提高A组模拟9.17】组合数问题

    [NOIP2017提高A组模拟9.17]组合数问题 题目 Description 定义"组合数"S(n,m)代表将n 个不同的元素拆分成m 个非空集合的方案数. 举个例子,将{1,2,3}拆分成2 个 ...

  6. JZOJ 【NOIP2017提高A组模拟9.14】捕老鼠

    JZOJ [NOIP2017提高A组模拟9.14]捕老鼠 题目 Description 为了加快社会主义现代化,建设新农村,农夫约(Farmer Jo)决定给农庄里的仓库灭灭鼠.于是,猫被农夫约派去捕 ...

  7. JZOJ 5246. 【NOIP2017模拟8.8A组】Trip(trip)

    5246. [NOIP2017模拟8.8A组]Trip(trip) (File IO): input:trip.in output:trip.out Time Limits: 1500 ms Memo ...

  8. JZOJ 5235. 【NOIP2017模拟8.7A组】好的排列

    5235. [NOIP2017模拟8.7A组]好的排列 (File IO): input:permutation.in output:permutation.out Time Limits: 1000 ...

  9. JZOJ 5236. 【NOIP2017模拟8.7A组】利普希茨

    5236. [NOIP2017模拟8.7A组]利普希茨 (File IO): input:lipschitz.in output:lipschitz.out Time Limits: 1000 ms ...

随机推荐

  1. 调整弹出对话框在ASP.NET应用程序的大小

    调整弹出对话框在ASP.NET应用程序的大小 #region 调整弹出对话框在ASP.NET应用程序的大小    protected void PopupWindowControl_Customize ...

  2. atitit.资源释放机制--attilax总结

    atitit.资源释放机制--attilax总结 1. .全手工, 1 2. 引用计数, 1 2.1. 成本也显而易见. 1 2.2. 循环引用的问题, 2 2.3. 引用计数方式事实上也有经典的卡顿 ...

  3. 关于GridView Master-Detail 不支持明细属性为IEnumerable、IList问题

    默认状态下gridview不支持接口集合,即不支持属性类型为IEnumerable<T>或者扩展的IList<T>,只能乖乖的转成List等实体集合,这种取舍就是鱼和熊掌了,如 ...

  4. unity, 替换shader渲染(Rendering with Replaced Shaders)

    实现特效,尤其是一些后处理特效,经常需要将各物体的shader替换为另一套shader进行渲染到纹理,再后再进行合成或以某种叠加方式叠加到最后的画面上去. 再复杂一点儿的,可能不同的物体所用的替换sh ...

  5. atitit.html5 vs 原生 app的区别与选择

    atitit.html5  vs 原生 app的区别与选择 1. html5的优点 1 1.1. 最大优势::在跨平台(ios苹果,android安卓等) 1 1.2. 开放性 1 1.3. 快速的更 ...

  6. I2C总线协议

     1.I2C协议   2条双向串行线,一条数据线SDA,一条时钟线SCL.   SDA传输数据是大端传输,每次传输8bit,即一字节.   支持多主控(multimastering),任何时间点只能有 ...

  7. JS自定义去除字符串左右两边的指定字符

    function ltrim(str,char){ var pos = str.indexOf(char); var sonstr = str.substr(pos+1); return sonstr ...

  8. 再谈API GateWay服务网关

    前面在谈微服务架构的时候,我博客上转过Chris Richardson 微服务系列中对微服务网关的描述: 通常来说,使用 API 网关是更好的解决方式.API 网关是一个服务器,也可以说是进入系统的唯 ...

  9. java 高精度 四则运算

    java的大数处理对于ACM中的大数来说,相当的简单啊: 整数的运算   BigInteger 小数的运算   BigDecimal 导入类: import java.util.Scanner; im ...

  10. rip中的连续子网以及不连续子网

    RIPv1 RIPv2 距离矢量2 距离矢量 最大跳计数15 最大跳计数15 有类的 无类的 基于广播的    基于组播224.0.09 不支持VLSM 支持VLSM 无认证 允许MD5认证 不支持不 ...