查询小于k的值

注意lower_bound一定要减去查找的起始位置得到正确的位置

调了快两天

#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cmath>
using namespace std;
int a[],b[],belong[],tag[],num,sz,n;
void calbe(int n){
for(int i=;i<=n;i++){
belong[i]=(i-)/sz+;
}
}
void reset(int l,int r){
for(int i=l;i<=r;i++)
b[i]=a[i];
sort(b+l,b+r+);
}
void update(int l,int r,int w){
int xl=belong[l];
int xr=belong[r];
for(int i=l;i<=min(r,sz*xl);i++){
a[i]+=w;
}
reset((xl-)*sz+,min(xl*sz,n));
if(xl!=xr){
for(int i=(xr-)*sz+;i<=r;i++)
a[i]+=w;
reset((xr-)*sz+,min(xr*sz,n));
}
for(int i=xl+;i<=xr-;i++)
tag[i]+=w; }
int query(int l,int r,int w){
// printf("qw=%d\n",w);
int xl=belong[l];
int xr=belong[r];
// printf("ln=%d || rn=%d\n",xl,xr);
int ans=;
for(int i=l;i<=min(r,sz*xl);i++){
// printf("tag=%d || qsw=%d\n",tag[xl],w-tag[xl]);
if(a[i]<w-tag[xl]){
ans++;
// printf("a[%d] = %d || w=%d ||tag=%d\n",i,a[i],w,tag[xl]);
}
}
if(xl!=xr){
for(int i=(xr-)*sz+;i<=r;i++){
// printf("tag=%d || qsw=%d\n",tag[xr],w-tag[xr]);
if(a[i]<w-tag[xr]){
ans++;
// printf("a[%d] = %d || w=%d ||tag=%d\n",i,a[i],w,tag[xl]);
}
}
}
for(int i=xl+;i<=xr-;i++){
int pos = lower_bound(b+sz*(i-)+,b+sz*i+,w-tag[i])-(b+(i-)*sz+);
// printf("pos/%d:%d st=%d \n",i,pos,(i-1)*sz+1);
ans+=pos;
}
return ans;
}
int main(){
scanf("%d",&n);
sz=sqrt(n);
calbe(n);
num=n/sz;
if(n%sz)
num++;
// printf("sz=%d\n",sz);
// for(int i=1;i<=n;i++)
// printf("%d ",belong[i]);
for(int i=;i<=n;i++)
scanf("%d",&a[i]);
for(int i=;i<=num;i++){
reset((i-)*sz+,min(sz*i,n));
}
// for(int i=1;i<=num;i++){
// printf("block:%d\nB: ",i);
// for(int j=(i-1)*sz+1;j<=i*sz;j++)
// printf("%d ",b[j]+tag[i]);
// printf("\nA: ");
// for(int j=(i-1)*sz+1;j<=i*sz;j++)
// printf("%d ",a[j]+tag[i]);
// printf("\n\n");
// }
for(int i=;i<=n;i++){
int opt,l,r,c;
scanf("%d %d %d %d",&opt,&l,&r,&c);
if(opt==){
update(l,r,c);
// for(int i=1;i<=num;i++){
// printf("block:%d tag:%d\nB: ",i,tag[i]);
// for(int j=(i-1)*sz+1;j<=i*sz;j++)
// printf("%d ",b[j]+tag[i]);
// printf("\nA: ");
// for(int j=(i-1)*sz+1;j<=i*sz;j++)
// printf("%d ",a[j]+tag[i]);
// printf("\n\n");
// }
}
else{
printf("%d\n",query(l,r,c*c));
}
}
return ;
}

题解——loj6278 数列分块入门2 (分块)的更多相关文章

  1. LibreOJ 6277 数列分块入门 1(分块)

    题解:感谢hzwer学长和loj让本蒟蒻能够找到如此合适的入门题做. 这是一道非常标准的分块模板题,本来用打标记的线段树不知道要写多少行,但是分块只有这么几行,极其高妙. 代码如下: #include ...

  2. LibreOJ 6280 数列分块入门 4(分块区间加区间求和)

    题解:分块的区间求和比起线段树来说实在是太好写了(当然,复杂度也高)但这也是没办法的事情嘛.总之50000的数据跑了75ms左右还是挺优越的. 比起单点询问来说,区间询问和也没有复杂多少,多开一个su ...

  3. LibreOJ 6278 数列分块入门 2(分块)

     题解:非常高妙的分块,每个块对应一个桶,桶内元素全部sort过,加值时,对于零散块O(sqrt(n))暴力修改,然后暴力重构桶.对于大块直接整块加.查询时对于非完整块O(sqrt(n))暴力遍历.对 ...

  4. [Libre 6281] 数列分块入门 5 (分块)

    水一道入门分块qwq 题面:传送门 开方基本暴力.. 如果某一个区间全部都开成1或0就打上标记全部跳过就行了 因为一个数开上个四五六次就是1了所以复杂度能过233~ code: //By Menteu ...

  5. LOJ.6284.数列分块入门8(分块)

    题目链接 \(Description\) 给出一个长为n的数列,以及n个操作,操作涉及区间询问等于一个数c的元素,并将这个区间的所有元素改为c. \(Solution\) 模拟一些数据可以发现,询问后 ...

  6. LibreOJ 6281 数列分块入门 5(分块区间开方区间求和)

    题解:区间开方emmm,这马上让我想起了当时写线段树的时候,很显然,对于一个在2^31次方以内的数,开方7-8次就差不多变成一了,所以我们对于每次开方,如果块中的所有数都为一了,那么开方也没有必要了. ...

  7. LibreOJ 6279 数列分块入门 3(分块+排序)

    题解:自然是先分一波块,把同一个块中的所有数字压到一个vector中,将每一个vector进行排序.然后对于每一次区间加,不完整的块加好后暴力重构,完整的块直接修改标记.查询时不完整的块暴力找最接近x ...

  8. LOJ.6281.数列分块入门5(分块 区间开方)

    题目链接 int内的数(也不非得是int)最多开方4.5次就变成1了,所以还不是1就暴力,是1就直接跳过. #include <cmath> #include <cstdio> ...

  9. [Libre 6282] 数列分块入门 6 (分块)

    原题:传送门 code: //By Menteur_Hxy #include<cstdio> #include<iostream> #include<algorithm& ...

随机推荐

  1. Robot Framework 遇到过的错误 1. Chrome打开无法数据网址,地址栏只显示data:,

    问题描述:用RF打开网页时未跳转到指定网址,而是显示data:, *** Settings ***Library SeleniumLibrary *** Test Cases ***Login_Tes ...

  2. 20155228 2016-2017-2 《Java程序设计》第9周学习总结

    20155228 2016-2017-2 <Java程序设计>第9周学习总结 教材学习内容总结 整合数据库 JDBC是用于执行SQL的解决方案,开发人员使用JDBC的标准接口,数据库厂商则 ...

  3. ReactiveCocoa(III)

    flatMap(FlattenStrategy.latest) observe(on: UIScheduler()).startWithResult 切换线程: observeOn(UISchedul ...

  4. 关于git上的一些错误信息

    如果输入$ Git remote add origin git@github.com:djqiang(github帐号名)/gitdemo(项目名).git 提示出错信息:fatal: remote ...

  5. mitmproxy 中间人攻击的小玩笑

    import mitmproxy.http from mitmproxy import ctx, http class Joker: def request(self, flow: mitmproxy ...

  6. maven build 的时候,卡死在Downloading metadata的解决方法

    [INFO] [INFO] ------------------------------------------------------------------------ [INFO] Buildi ...

  7. vue 父子组件

    组件 什么是组件? 组件 (Component) 是 Vue.js 最强大的功能之一.组件可以扩展 HTML 元素,封装可重用的代码.在较高层面上,组件是自定义元素,Vue.js 的编译器为它添加特殊 ...

  8. ajax 检测用户名是否可用

    下面是一个 ajax 检测用户名是否可用的例子. django  项目中. —— views.py 里—— from django.shortcuts import render,HttpRespon ...

  9. 有登陆认证的情况下如何使用Wisdom RESTClient?

    访问REST API时,很多系统需要登陆认证,登陆成功以后才允许访问API.下面介绍一下有登陆认证情况下如何使用 Wisdom RESTClient测试API的方法. 方法很简单即在浏览器上成功登录系 ...

  10. composer 报错:Failed to decode response: zlib_decode(): data error 解决办法

    执行命令 composer require particle/validator 报错 Failed to decode response: zlib_decode(): data error 网上推 ...