裸题...

  依旧是写了BIT和线段树两种(才不是写完线段树后才想起来可以写BIT呢

  怎么卡常数都挺大...QAQ ccz和yy的写法好快哇%%%

BIT:

#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<queue>
#include<map>
#define ll long long
using namespace std;
const int maxn=,inf=1e9;
struct poi{int fir,sec,trd,ty,pos,w;}a[maxn];
int n,m,x,y,z,cnt,N,x1,x2,y1,y2;
int b[maxn];
ll tree[maxn],ans[maxn];
void read(int &k)
{
int f=;k=;char c=getchar();
while(c<''||c>'')c=='-'&&(f=-),c=getchar();
while(c<=''&&c>='')k=k*+c-'',c=getchar();
k*=f;
}
inline bool cmp(poi a,poi b){return a.fir==b.fir?a.ty<b.ty:a.fir<b.fir;}
inline int lowbit(int x){return x&-x;}
inline void add(int x,int delta){for(;x<=N;x+=lowbit(x))tree[x]+=delta;}
inline ll query(int x){ll sum=;for(;x;x-=lowbit(x))sum+=tree[x];return sum;}
int main()
{
read(n);read(m);cnt=n;
for(int i=;i<=n;i++)
{
read(x);read(y);read(z);
a[i].fir=x;a[i].sec=y;a[i].w=z;b[++N]=y;
}
for(int i=;i<=m;i++)
{
read(x1);read(y1);read(x2);read(y2);
a[++cnt].fir=x1;a[cnt].sec=y1;a[cnt].trd=y2;a[cnt].ty=-;a[cnt].pos=i;
a[++cnt]=a[cnt-];a[cnt].fir=x2;a[cnt].ty=;b[++N]=y1;b[++N]=y2;
}
sort(b+,b++N);
for(int i=;i<=n;i++)a[i].sec=lower_bound(b+,b++N,a[i].sec)-b;
for(int i=n+;i<=cnt;i+=)
{
a[i].sec=a[i+].sec=lower_bound(b+,b++N,a[i].sec)-b;
a[i].trd=a[i+].trd=lower_bound(b+,b++N,a[i].trd)-b;
}
sort(a+,a++cnt,cmp);
for(int i=;i<=cnt;i++)
{
if(a[i].ty)
{
ll sum=query(a[i].trd)-query(a[i].sec-);
ans[a[i].pos]+=(a[i].ty==?sum:-sum);
}
else add(a[i].sec,a[i].w);
}
for(int i=;i<=m;i++)printf("%lld\n",ans[i]);
return ;
}

线段树:

#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<queue>
#include<map>
#define ll long long
using namespace std;
const int maxn=,inf=1e9;
struct poi{int fir,sec,trd,ty,pos,w;}a[maxn];
int n,m,x,y,z,cnt,N,x1,x2,y1,y2;
int b[maxn];
ll tree[maxn*],ans[maxn];
void read(int &k)
{
int f=;k=;char c=getchar();
while(c<''||c>'')c=='-'&&(f=-),c=getchar();
while(c<=''&&c>='')k=k*+c-'',c=getchar();
k*=f;
}
inline bool cmp(poi a,poi b){return a.fir==b.fir?a.ty<b.ty:a.fir<b.fir;}
inline void pushup(int x){tree[x]=tree[x<<]+tree[x<<|];}
inline void add(int x,int l,int r,int cx,int delta)
{
if(l==r){tree[x]+=delta;return;}
int mid=(l+r)>>;
if(cx<=mid)add(x<<,l,mid,cx,delta);
else add(x<<|,mid+,r,cx,delta);
pushup(x);
}
inline ll query(int x,int l,int r,int cl,int cr)
{
if(cl<=l&&r<=cr)return tree[x];
int mid=(l+r)>>;ll ret=;
if(cl<=mid)ret+=query(x<<,l,mid,cl,cr);
if(cr>mid)ret+=query(x<<|,mid+,r,cl,cr);
return ret;
}
int main()
{
read(n);read(m);cnt=n;
for(int i=;i<=n;i++)
{
read(x);read(y);read(z);
a[i].fir=x;a[i].sec=y;a[i].w=z;b[++N]=y;
}
for(int i=;i<=m;i++)
{
read(x1);read(y1);read(x2);read(y2);
a[++cnt].fir=x1;a[cnt].sec=y1;a[cnt].trd=y2;a[cnt].ty=-;a[cnt].pos=i;
a[++cnt]=a[cnt-];a[cnt].fir=x2;a[cnt].ty=;b[++N]=y1;b[++N]=y2;
}
sort(b+,b++N);
for(int i=;i<=n;i++)a[i].sec=lower_bound(b+,b++N,a[i].sec)-b;
for(int i=n+;i<=cnt;i+=)
{
a[i].sec=a[i+].sec=lower_bound(b+,b++N,a[i].sec)-b;
a[i].trd=a[i+].trd=lower_bound(b+,b++N,a[i].trd)-b;
}
sort(a+,a++cnt,cmp);
for(int i=;i<=cnt;i++)
{
if(a[i].ty)
{
ll sum=query(,,N,a[i].sec,a[i].trd);
ans[a[i].pos]+=(a[i].ty==?sum:-sum);
}
else add(,,N,a[i].sec,a[i].w);
}
for(int i=;i<=m;i++)printf("%lld\n",ans[i]);
return ;
}

在yy大爷的指导下卡了一波常...艹上了#7,但是写得丑还是写得丑比yy大爷还是慢不少

#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<queue>
#include<map>
#define ll long long
using namespace std;
const int maxn=,inf=1e9;
struct poi{int fir,sec,trd,ty,pos;}a[maxn];
int n,m,x,y,z,cnt,N,x1,x2,y1,y2;
int b[maxn],w[maxn];
ll tree[maxn],ans[maxn];
char buf[],*ptr=buf-;
int read()
{
int x=,f=,c=*++ptr;
while(c<)c=='-'&&(f=-),c=*++ptr;
while(c>)x=x*+c-,c=*++ptr;
return x*f;
}
inline bool cmp(poi a,poi b){return a.fir==b.fir?a.ty<b.ty:a.fir<b.fir;}
inline int lowbit(int x){return x&-x;}
inline void add(int x,int delta){for(;x<=N;x+=lowbit(x))tree[x]+=delta;}
inline ll query(int x){ll sum=;for(;x;x-=lowbit(x))sum+=tree[x];return sum;}
int main()
{
fread(buf,,sizeof(buf),stdin)[buf]=;
n=read();m=read();cnt=n;
for(int i=;i<=n;i++)
{
x=read();y=read();w[i]=read();
a[i].fir=x;a[i].sec=y;a[i].pos=i;b[++N]=y;
}
for(int i=;i<=m;i++)
{
x1=read();y1=read();x2=read();y2=read();
a[++cnt].fir=x1;a[cnt].sec=y1;a[cnt].trd=y2;a[cnt].ty=-;a[cnt].pos=i;
a[++cnt]=a[cnt-];a[cnt].fir=x2;a[cnt].ty=;
}
sort(b+,b++N);
for(int i=;i<=n;i++)a[i].sec=lower_bound(b+,b++N,a[i].sec)-b;
for(int i=n+;i<=cnt;i+=)
{
a[i].sec=a[i+].sec=lower_bound(b+,b++N,a[i].sec)-b;
a[i].trd=a[i+].trd=upper_bound(b+,b++N,a[i].trd)-b-;
}
sort(a+,a++cnt,cmp);
for(int i=;i<=cnt;i++)
{
if(a[i].ty)
{
ll sum=query(a[i].trd)-query(a[i].sec-);
ans[a[i].pos]+=(a[i].ty==?sum:-sum);
}
else add(a[i].sec,w[a[i].pos]);
}
for(int i=;i<=m;i++)printf("%lld\n",ans[i]);
return ;
}

bzoj4822: [Cqoi2017]老C的任务(扫描线+BIT/线段树)的更多相关文章

  1. [BZOJ4822][CQOI2017]老C的任务(扫描线+树状数组)

    4822: [Cqoi2017]老C的任务 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 379  Solved: 203[Submit][Statu ...

  2. [bzoj4822][Cqoi2017]老C的任务&[bzoj1935][Shoi2007]Tree 园丁的烦恼

    来自FallDream的博客,未经允许,请勿转载,谢谢. 老 C 是个程序员.     最近老 C 从老板那里接到了一个任务——给城市中的手机基站写个管理系统.作为经验丰富的程序员,老 C 轻松地完成 ...

  3. HDU - 1542 扫描线入门+线段树离散化

    扫描线算法+线段树维护简介: 像这种求面积的并集的题目,就适合用扫描线算法解决,具体来说就是这样 类似这种给出点的矩形的对角的点的坐标,然后求出所有矩形面积的交集的问题,可以采用扫描线算法解决.图如下 ...

  4. Atlantis HDU - 1542 (扫描线,线段树)

    扫描线的模板题,先把信息接收,然后排序,记录下上边和下边,然后用一条虚拟的线从下往上扫.如果我扫到的是下边,那么久用线段树在这个区间内加上1,表示这个区间现在是有的,等我扫描到上边的时候在加上-1,把 ...

  5. poj 2482 Stars in Your Window + 51Nod1208(扫描线+离散化+线段树)

    Stars in Your Window Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 13196   Accepted:  ...

  6. 【BZOJ 3958】 3958: [WF2011]Mummy Madness (二分+扫描线、线段树)

    3958: [WF2011]Mummy Madness Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 96  Solved: 41 Descripti ...

  7. 洛谷 P4125 [WC2012]记忆中的水杉树【扫描线+set+线段树】

    我没有找到能在bzojAC的代码--当然我也WA了--但是我在洛谷过了,那就假装过了吧 minmax线段树一开始写的只能用min更新min,max更新max,实际上是可以互相更新的-- 首先看第二问, ...

  8. BZOJ4822[Cqoi2017]老C的任务——树状数组(二维数点)

    题目描述 老 C 是个程序员.     最近老 C 从老板那里接到了一个任务——给城市中的手机基站写个管理系统.作为经验丰富的程序员,老 C 轻松 地完成了系统的大部分功能,并把其中一个功能交给你来实 ...

  9. [BZOJ4822] [CQOI2017] 老C的任务

    题目链接 BZOJ:https://lydsy.com/JudgeOnline/problem.php?id=4822. 洛谷:https://www.luogu.org/problemnew/sho ...

随机推荐

  1. Visual Stdio Code编辑Mark Down

    Visual Studio Code可以一边写Markdown一边预览了,而且不需要任何插件. 方法如下: 新建一个文件,以 .md 为后缀: Visual Studio Code 原生就支持高亮Ma ...

  2. Halcon10 下载

    Halcon10 下载地址:http://www.211xun.com/download_page_1.html HALCON 10 是一套机器视觉图像处理库,由一千多个算子以及底层的数据管理核心构成 ...

  3. CVPR-2018 那些有趣的新想法

    Taylor Guo @ Shanghai - 2018.10.18 缘起 还有什么比顶级会议更适合寻找有趣新想法的地方吗?我们从CVPR 2018 计算机视觉和模式识别的顶级会议中发现了很多有趣的东 ...

  4. opencv-学习笔记(2)

    opencv-学习笔记(2) 这章记录了 获取像素点,改变像素点 获取图像的属性(行,列,通道数,数据类型) roi感应区 拆分以及合并图像通道 边缘扩充 opencv获取像素点,改变像素点 ---- ...

  5. selenium元素定位不到之iframe---基于python

    我们在使用selenium的18中定位方式的时候,有时会遇到定位不上的问题,今天我们就来说说导致定位不上的其中一个原因---iframe 问题描述:通过firebug查询到相应元素的id或name等, ...

  6. JavaScript筑基篇(三)->JS原型和原型链的理解

    删除理由:很久以前写的,当时理解不够深入,这样描述反而看起来更复杂了.因此就删掉,免得误人子弟! 可以看看另一篇文章:[如何继承Date对象?由一道题彻底弄懂JS继承.](http://www.cnb ...

  7. 默认初始化&拷贝初始化&直接初始化&值初始化&列表初始化

    一.各种初始化的形式 /* 定义变量形式一:不指定初始值 */ int a; // 默认初始化 /* 定义变量形式二:指定初始值 */ int b = 1; // 拷贝初始化 int b(1); // ...

  8. “Hello world!”贡献分分配规则

    规则1:得到总分后取14分,剩下分数进行平分.(备注:例如得了50分,取出14分,剩下36分组内进行平分) 规则2:对于会议准时参加者每人加0.5分.(备注:按通知开会时间为准,准时到者实行加分.) ...

  9. Coursera-Note: Internet History, Technology and Secure (1st week to 9th week)

    目录 Coursera-Note: Internet History, Technology and Secure 第一周 第二周 数据交换: Packet switching技术: 第三周 创造ht ...

  10. 共享程序集GAC

    原文标题: 原文地址:https://www.cnblogs.com/1996V/p/9037603.html 共享程序集GAC 我上面说了这么多有关CLR加载程序集的细节和规则,事实上,类似于msc ...