LINK:数列

需要动一点脑子 考虑查询 暴力显然不行 考虑把绝对值拆开。

当x<=y ax<=ay时 有 y-x+ay-ax<=k x+ax>=y+ay-k 可以发现在满足前两个条件下第三个条件是这样才会被统计贡献。

剩下3种情况分别是 x+ax<=k+ay+y x-ax<=k+y-ay ax-x=k-y+ay

可以发现 这个类似于三维偏序问题 我们进行三维数点即可 但是由于操作有时间关系 上CDQ的话就变成了四维偏序。

直接KD tree即可。考虑修改操作 其实就是插入 由于历史版本还有我们不需要删除。

考虑替罪羊树维护。

//#include<bits\stdc++.h>
#include<iostream>
#include<iomanip>
#include<cstdio>
#include<cstring>
#include<string>
#include<ctime>
#include<cmath>
#include<cctype>
#include<cstdlib>
#include<queue>
#include<deque>
#include<stack>
#include<vector>
#include<algorithm>
#include<utility>
#include<bitset>
#include<set>
#include<map>
#define ll long long
#define db double
#define INF 1000000000
#define ld long double
#define pb push_back
#define get(x) x=read()
#define gt(x) scanf("%d",&x)
#define put(x) printf("%d\n",x)
#define rep(p,n,i) for(RE int i=p;i<=n;++i)
#define go(x) for(int i=lin[x],tn=ver[i];i;tn=ver[i=nex[i]])
#define pii pair<int,int>
#define F first
#define S second
#define mk make_pair
#define mod 1000000007
#define RE register
using namespace std;
char buf[1<<15],*fs,*ft;
inline char getc()
{
return (fs==ft&&(ft=(fs=buf)+fread(buf,1,1<<15,stdin),fs==ft))?0:*fs++;
}
inline int read()
{
RE int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x*f;
}
const db alpha=0.75;
const int MAXN=110000;
const int K=3;
int n,Q,cnt,D,top,ans,root;
char a[10];
struct wy
{
int l,r;
int mx[K],mn[K];
int d[K];//自己本身元素
int sum;
}t[MAXN<<2];
int q[MAXN<<2],b[MAXN];
inline int cmp(int a,int b){return t[a].d[D]<t[b].d[D];}
inline void pushup(int p)
{
int l=t[p].l;int r=t[p].r;
t[p].sum=t[l].sum+t[r].sum+1;
rep(0,K-1,i)
{
if(l)t[p].mx[i]=max(t[l].mx[i],t[p].mx[i]),t[p].mn[i]=min(t[p].mn[i],t[l].mn[i]);
if(r)t[p].mx[i]=max(t[r].mx[i],t[p].mx[i]),t[p].mn[i]=min(t[p].mn[i],t[r].mn[i]);
}
}
inline int build(int l,int r,int k)
{
if(l>r)return 0;
int mid=(l+r)>>1;D=k;
nth_element(q+l,q+mid,q+1+r,cmp);
rep(0,K-1,i)t[q[mid]].mx[i]=t[q[mid]].mn[i]=t[q[mid]].d[i];
t[q[mid]].l=build(l,mid-1,(k+1)%K);
t[q[mid]].r=build(mid+1,r,(k+1)%K);
pushup(q[mid]);return q[mid];
}
inline void dfs(int x)
{
if(!x)return;
q[++top]=x;
if(t[x].l)dfs(t[x].l);
if(t[x].r)dfs(t[x].r);
}
inline void insert(int &p,int x,int k,int flag)
{
if(!p)
{
p=x;t[p].sum=1;
rep(0,K-1,i)t[p].mx[i]=t[p].mn[i]=t[p].d[i];
return;
}
int mark=0;
if(t[x].d[k]<t[p].d[k])
{
if(t[t[p].l].sum>=t[p].sum*alpha)mark=1;
insert(t[p].l,x,(k+1)%K,flag|mark);
}
else
{
if(t[t[p].r].sum>=t[p].sum*alpha)mark=1;
insert(t[p].r,x,(k+1)%K,flag|mark);
}
if(mark&&!flag)top=0,dfs(p),p=build(1,top,k);
else pushup(p);
}
inline int check(int x)
{
rep(0,K-1,i)if(t[x].mx[i]>q[i])return 0;
return 1;
}
inline int check_point(int x)
{
rep(0,K-1,i)if(t[x].d[i]>q[i])return 0;
return 1;
}
inline int check_range(int x)
{
rep(0,K-1,i)if(t[x].mn[i]>q[i])return 0;
return 1;
}
inline void ask(int x)
{
if(check(x)){ans+=t[x].sum;return;}
if(check_point(x))++ans;
if(t[x].l&&check_range(t[x].l))
ask(t[x].l);
if(t[x].r&&check_range(t[x].r))
ask(t[x].r);
}
int main()
{
freopen("1.in","r",stdin);
get(n);get(Q);
rep(1,n,i)
{
int x;get(x);b[i]=x;
t[++cnt].d[0]=i;t[cnt].d[1]=x;t[cnt].d[2]=-i-x;q[cnt]=cnt;
t[++cnt].d[0]=-i;t[cnt].d[1]=-x;t[cnt].d[2]=i+x;q[cnt]=cnt;
t[++cnt].d[0]=-i;t[cnt].d[1]=x;t[cnt].d[2]=i-x;q[cnt]=cnt;
t[++cnt].d[0]=i;t[cnt].d[1]=-x;t[cnt].d[2]=x-i;q[cnt]=cnt;
}
root=build(1,cnt,0);
rep(1,Q,i)
{
scanf("%s",a+1);
if(a[1]=='M')
{
int x,y;get(x);get(y);b[x]=y;
t[++cnt].d[0]=x;t[cnt].d[1]=y;t[cnt].d[2]=-x-y;insert(root,cnt,0,0);
t[++cnt].d[0]=-x;t[cnt].d[1]=-y;t[cnt].d[2]=y+x;insert(root,cnt,0,0);
t[++cnt].d[0]=-x;t[cnt].d[1]=y;t[cnt].d[2]=x-y;insert(root,cnt,0,0);
t[++cnt].d[0]=x;t[cnt].d[1]=-y;t[cnt].d[2]=y-x;insert(root,cnt,0,0);
}
else
{
ans=0;int x,y;get(x);get(y);
//x<=y ax<=ay -x-ax<=-y-ay+k 也统计x相等y相等
q[0]=x;q[1]=b[x];q[2]=-x-b[x]+y;ask(root);
//x>=y ax>ay x+ax<=k+ay+y
q[0]=-x;q[1]=-b[x]-1;q[2]=x+b[x]+y;ask(root);
//x>y ax<=ay x-ax<=k+y-ay
q[0]=-x-1;q[1]=b[x];q[2]=y+x-b[x];ask(root);
//x<y ax>=ay -x+ax<=k+ay-y;
q[0]=x-1;q[1]=-b[x];q[2]=y+b[x]-x;ask(root);
put(ans);
}
}
return 0;
}

代码写的有问题 我这样做应该建立四棵KD-tree。

或者 写四个ask 我觉得。

网上题解都是旋转坐标系转契比雪夫距离了。我思考一下我这种做法对不对。

bzoj 2989: 数列的更多相关文章

  1. [BZOJ 2989]数列(二进制分组+主席树)

    [BZOJ 2989]数列(二进制分组+主席树) 题面 给定一个长度为n的正整数数列a[i]. 定义2个位置的graze值为两者位置差与数值差的和,即graze(x,y)=|x-y|+|a[x]-a[ ...

  2. [BZOJ 2989]数列(CDQ 分治+曼哈顿距离与切比雪夫距离的转化)

    [BZOJ 2989]数列(CDQ 分治) 题面 给定一个长度为n的正整数数列a[i]. 定义2个位置的graze值为两者位置差与数值差的和,即graze(x,y)=|x-y|+|a[x]-a[y]| ...

  3. BZOJ 2989: 数列/4170: 极光

    题解: n倍经验题 首先比较容易想到的是对绝对值分类讨论 然后是4维偏序 1.查询和修改顺序 2.x>y 3.a[x]>a[y] 4.(x+a[x])-(y+a[y])<=k 这样是 ...

  4. 解题:BZOJ 2989 数列

    题面 学习二进制分组 题目本身可以看成二维平面上的问题,转成切比雪夫距离后就是矩形和了 二进制分组是将每个修改添加到末尾,然后从后往前二进制下进位合并,这样最多同时有$\log n$组,每个修改只会被 ...

  5. BZOJ #2989. 数列 [树套树]

    考虑转化问题模型,这个没必要可持久化,直接加点就可以了,还不用删点 每次的问题是求 曼哈顿距离,变成切比雪夫距离然后求解 然后我们考虑将这玩意旋转 45度, 然后原坐标的 \((x,y)\) 会变成 ...

  6. bzoj 4303 数列

    bzoj 4303 数列 二维 \(KD-Tree\) 模板题. \(KD-Tree\) 虽然在更新和查询的方式上类似于线段树,但其本身定义是类似于用 \(splay/fhq\ treap\) 维护区 ...

  7. BZOJ 3142 数列(组合)

    题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=3142 题意:给出n,K,m,p.求有多少长度为K的序列A,满足:(1)首项为正整数:(2 ...

  8. BZOJ 4305: 数列的GCD( 数论 )

    对于d, 记{ai}中是d的倍数的数的个数为c, 那么有: 直接计算即可,复杂度O(NlogN+MlogM) --------------------------------------------- ...

  9. bzoj 4305 数列的GCD

    LINK:数列的GCD 题意: 给出一个长度为N的数列{a[n]},1<=a[i]<=M(1<=i<=N). 现在问题是,对于1到M的每个整数d,有多少个不同的数列b[1], ...

随机推荐

  1. 常用API - Arrays、Math、Object

    Arrays类 概述 此类包含用来操作数组(比如排序和搜索)的各种方法.此类还包含一个允许将数组作为列表来查看的静态工厂. 除非特别注明,否则如果指定数组引用为 null,则此类中的方法都会抛出 Nu ...

  2. ASP.NET CORE MVC用时分析工具MiniProfiler

    ASP.NET CORE MVC用时分析工具MiniProfiler MiniProfiler(https://miniprofiler.com/)是一个轻量级且简单易用的分析工具库,它可以用来分析A ...

  3. Dot Net Core中间件内部运行机制

    public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { if (env.IsDevelopment()) { ...

  4. day11总结

    """1.什么是函数 具备某一功能的工具===>函数 事先准备工具的过程===>函数的定义 遇到应用场景拿来就用=>函数的调用 2.为何要有函数 内置函 ...

  5. day24 常用模块(下)

    目录 一.logging模块 1 日志级别 2 默认级别为warning,默认打印到终端 3 为logging模块指定全局配置,针对所有的logger有效,控制打印到文件中 4.logging配置文件 ...

  6. Scala 面向对象(二):package 包 (一) 入门

    1 Scala包的基本介绍 和Java一样,Scala中管理项目可以使用包,但Scala中的包的功能更加强大,使用也相对复杂些,下面我们学习Scala包的使用和注意事项. 2 Scala包快速入门 使 ...

  7. python数据处理(一)之供机器读取的数据 csv,json,xml

    代码与资料 https://github.com/jackiekazil/data-wrangling 1 csv 1.1导入csv数据 1.2将代码保存到文件中并在命令行中运行 2.json 2 导 ...

  8. Spring入门案例

    一.Spring基本介绍 1.什么是Spring Spring 是分层的 Java SE/EE 应用 full-stack 轻量级开源框架,以 IoC(Inverse Of Control: 反转控制 ...

  9. iis 0x80070032 Cannot read configuration file because it exceeds the maximum file size

    问题:iis部署了网站,由于webconfig文件过大(251kb,默认250kb)导致网站报错 0x80070032 Cannot read configuration file because i ...

  10. (4)webpack中配置css,scss,less第三方loader

    为什么要使用第三方loader 一般引入样式文件,我们会在html中引入样式标签. 很明显,这样就跟之前在script中引入js文件一样,会导致二次请求.我们希望webpack像处理js文件一样处理样 ...