我们可以发现所有的操作当中,只有坐标的增加,没有坐标的减少。

所以我们可以发现这么一个简单的事实,一条鱼一旦出了渔网,那么它就不可能再回来。

但是目前这并没有什么卵用。

我们可以把询问一个矩阵当中的鱼的数量转化为分别求这个矩阵的四个角的左下角的鱼的数量。又因为我们发现x和y的坐标是独立的,所以我们可以分别维护。

维护这个东西本人使用的线段树,在这里维护了八颗线段树。

然后在维护的过程中,八颗线段树应该是两两配对维护的,也就是x坐标和y坐标应该一同维护,因为我们维护的是某一个点的左下角的点的数量,所以我们在维护任意一对线段树时,如果我们发现某一个点的某一维超过了限制,那么就直接删除这个点(删除这个点的时候直接将两个坐标置为-inf)保证它不会再次影响到答案(好吧,这个性质还是有卵用的)。

这道题实际上是考察代码力。。。 。。。

 #include <queue>
#include <cstdio>
#include <cstring>
#include <climits>
#include <algorithm>
using namespace std;
typedef long long ll;
template<typename T>inline void read(T &x){
x=;char ch;bool flag = false;
while(ch=getchar(),ch<'!');if(ch == '-') ch=getchar(),flag = true;
while(x=*x+ch-'',ch=getchar(),ch>'!');if(flag) x=-x;
}
inline ll cat_min(const ll &a,const ll &b){return a<b ? a:b;}
inline ll cat_max(const ll &a,const ll &b){return a>b ? a:b;}
const int maxn = ;
const ll inf = LLONG_MAX>>;
int n,m,X[maxn],Y[maxn];
int sum[maxn<<][];
ll max_x[maxn<<][],max_y[maxn<<][];
ll lazy_x[maxn<<][],lazy_y[maxn<<][];
int stander_x[],stander_y[];
int ls,rs,dx,idx;
inline void push_down(int x){
if(lazy_x[x][idx]){
max_x[x<<][idx] += lazy_x[x][idx];
lazy_x[x<<][idx] += lazy_x[x][idx];
max_x[x<<|][idx] += lazy_x[x][idx];
lazy_x[x<<|][idx] += lazy_x[x][idx];
lazy_x[x][idx] = ;
}
if(lazy_y[x][idx]){
max_y[x<<][idx] += lazy_y[x][idx];
lazy_y[x<<][idx] += lazy_y[x][idx];
max_y[x<<|][idx] += lazy_y[x][idx];
lazy_y[x<<|][idx] += lazy_y[x][idx];
lazy_y[x][idx] = ;
}
return ;
}
inline void update(int x){
sum[x][idx] = sum[x<<][idx] + sum[x<<|][idx];
max_x[x][idx] = cat_max(max_x[x<<][idx],max_x[x<<|][idx]);
max_y[x][idx] = cat_max(max_y[x<<][idx],max_y[x<<|][idx]);
return ;
}
void build(int rt,int l,int r){
lazy_x[rt][idx] = lazy_y[rt][idx] = ;
if(l == r){
if(X[l] <= stander_x[idx] && Y[l] <= stander_y[idx]){
sum[rt][idx] = ;
max_x[rt][idx] = X[l];
max_y[rt][idx] = Y[l];
}else{
sum[rt][idx] = ;
max_x[rt][idx] = -inf;
max_y[rt][idx] = -inf;
} return;
}
int mid = l+r >> ;
build(rt<<,l,mid);
build(rt<<|,mid+,r);
update(rt);
}
void modify_x(int rt,int l,int r){
if(ls <= l && r <= rs){
lazy_x[rt][idx] += dx;
max_x[rt][idx] += dx;
return;
}
push_down(rt);
int mid = l+r >> ;
if(ls <= mid) modify_x(rt<<,l,mid);
if(rs > mid) modify_x(rt<<|,mid+,r);
update(rt);
}
void modify_y(int rt,int l,int r){
if(ls <= l && r <= rs){
lazy_y[rt][idx] += dx;
max_y[rt][idx] += dx;
return;
}
push_down(rt);
int mid = l+r >> ;
if(ls <= mid) modify_y(rt<<,l,mid);
if(rs > mid) modify_y(rt<<|,mid+,r);
update(rt);
}
ll query(int rt,int l,int r){
if(ls <= l && r <= rs) return sum[rt][idx];
push_down(rt);
int mid = l+r >> ;
if(rs <= mid) return query(rt<<,l,mid);
if(ls > mid) return query(rt<<|,mid+,r);
return query(rt<<,l,mid) + query(rt<<|,mid+,r);
}
void prse(int rt,int l,int r){
if(max_x[rt][idx] <= stander_x[idx] && max_y[rt][idx] <= stander_y[idx]) return;
if(l == r){
sum[rt][idx] = ;
max_x[rt][idx] = -inf;
max_y[rt][idx] = -inf;
return;
}
push_down(rt);
int mid = l+r >> ;
prse(rt<<,l,mid);
prse(rt<<|,mid+,r);
update(rt);
}
inline void work(){
int n;read(n);
int x1,y1,x2,y2;
read(x1);read(y1);read(x2);read(y2);
stander_x[] = x2;stander_y[] = y2;
stander_x[] = x1-;stander_y[] = y2;
stander_x[] = x2;stander_y[] = y1-;
stander_x[] = x1-;stander_y[] = y1-;
for(int i=;i<=n;++i) read(X[i]),read(Y[i]);
for(idx = ;idx < ;++ idx) build(,,n),prse(,,n);
int m;read(m);
for(int i=,op;i<=m;++i){
read(op);read(ls);read(rs);
if(op == ){
read(dx);
for(idx = ;idx < ;++idx) modify_x(,,n),prse(,,n);
}else if(op == ){
read(dx);
for(idx = ;idx < ;++idx) modify_y(,,n),prse(,,n);
}else{
static ll num[];
for(idx = ;idx < ;++idx)
num[idx] = query(,,n);
// printf("I got it:: %d %d %d %d\n",num[3],num[2],num[1],num[0]);
ll ans = num[] - num[] - num[] + num[];
printf("%lld\n",ans);
}
}
}
int main(){
freopen("skyfishs.in","r",stdin);
freopen("skyfishs.out","w",stdout);
int T;read(T);
while(T--) work();
getchar();getchar();
fclose(stdin);fclose(stdout);
return ;
}

COGS 2533. [HZOI 2016]小鱼之美的更多相关文章

  1. COGS 2532. [HZOI 2016]树之美 树形dp

    可以发现这道题的数据范围有些奇怪,为毛n辣么大,而k只有10 我们从树形dp的角度来考虑这个问题. 如果我们设f[x][k]表示与x距离为k的点的数量,那么我们可以O(1)回答一个询问 可是这样的话d ...

  2. COGS 2416.[HZOI 2016]公路修建 & COGS 2419.[HZOI 2016]公路修建2 题解

    大意: [HZOI 2016]公路修建 给定一个有n个点和m-1组边的无向连通图,其中每组边都包含一条一级边和一条二级边(连接的顶点相同),同一组边中的一级边权值一定大于等于二级边,另外给出一个数k( ...

  3. cogs——2478. [HZOI 2016]简单的最近公共祖先

    2478. [HZOI 2016]简单的最近公共祖先 ★☆   输入文件:easy_LCA.in   输出文件:easy_LCA.out   简单对比时间限制:2 s   内存限制:128 MB [题 ...

  4. COGS 2199. [HZOI 2016] 活动投票

    2199. [HZOI 2016] 活动投票 ★★   输入文件:hztp.in   输出文件:hztp.out   简单对比时间限制:0.5 s   内存限制:2 MB [题目描述] 衡中活动很多, ...

  5. COGS 2485. [HZOI 2016]从零开始的序列

    2485. [HZOI 2016]从零开始的序列 ★★   输入文件:sky_seq.in   输出文件:sky_seq.out   简单对比时间限制:1 s   内存限制:256 MB [题目描述] ...

  6. COGS 2334. [HZOI 2016]最小函数值

    时间限制:1 s   内存限制:128 MB [题目描述] 有n个函数,分别为F1,F2,...,Fn.定义Fi(x)=Aix2+Bix+Ci(x∈N∗).给定这些Ai.Bi和Ci,请求出所有函数的所 ...

  7. cogs——2419. [HZOI 2016]公路修建2

    2419. [HZOI 2016]公路修建2 ★☆   输入文件:hzoi_road2.in   输出文件:hzoi_road2.out   简单对比时间限制:1 s   内存限制:128 MB [题 ...

  8. cogs——2416. [HZOI 2016]公路修建

    2416. [HZOI 2016]公路修建 ★☆   输入文件:hzoi_road.in   输出文件:hzoi_road.out   简单对比时间限制:1 s   内存限制:128 MB [题目描述 ...

  9. cogs 2478. [HZOI 2016]简单的最近公共祖先

    2478. [HZOI 2016]简单的最近公共祖先 ★☆   输入文件:easy_LCA.in   输出文件:easy_LCA.out   简单对比时间限制:2 s   内存限制:128 MB [题 ...

随机推荐

  1. web.xml中url-pattern的用法

    目录结构: // contents structure [-] url-pattern的三种写法 servlet匹配原则 filter匹配原则 语法错误的后果 参考文章 一.url-pattern的三 ...

  2. ArcGIS Engine开发之地图文档保存

    在对地图文档进行修改后,经常需要对其进行保存.地图文档的保存有直接保存和另存为两种方式.这里的地图文档的修改指的是修改地图文档文件记录信息,不是对空间数据的编辑. 1.地图文档保存 具体实现的思路: ...

  3. JavaScript图表FusionCharts免费在线公开课,由印度原厂技术工程师主讲,10月13日发车

    FusionCharts公开课达人还你做 轻松晋升图表大师 [开课时间]10月13日 14:30[主讲老师]印度原厂技术工程师[开课形式]网络在线公开课[活动费用]前50名免费 现在就可以报名哦  报 ...

  4. Android面试题--事件处理

    1.Handler 机制 Android 中主线程也叫 UI 线程,那么从名字上我们也知道主线程主要是用来创建.更新 UI 的,而其他耗时操作,比如网络访问,或者文件处理,多媒体处理等都需要在子线程中 ...

  5. DXGI 1.4的新特性

    其实到写这篇文章的时候,DXGI已经出1.5版了,但很多朋友实际上还在用1.2甚至1.1,所以现在谈1.4一点也不过时,而且1.4又是一次非常重大的更新,很值得仔细谈谈. 为了支持Direct3D 1 ...

  6. mysq l错误Table ‘./mysql/proc’ is marked as crashed and should be repaired

    续上一篇,解决了上一篇中的问题后,启动成功,但是在数据库中操作会存在一些问题,一些操作报一下异常: Table './mysql/proc' is marked as crashed and shou ...

  7. JavaScript & PHP模仿C#中string.format效果

    1.JavaScript function stringformat() { var args = Array.prototype.slice.call(arguments); if (args.le ...

  8. ORACLE分区表梳理系列(一)- 分区表概述、分类、使用方法及注意事项

    版权声明:本文发布于http://www.cnblogs.com/yumiko/,版权由Yumiko_sunny所有,欢迎转载.转载时,请在文章明显位置注明原文链接.若在未经作者同意的情况下,将本文内 ...

  9. 无法解析指定对象的 TargetProperty (UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleX)“的异常解决

    最近在写动画的时候做一个倒计时的效果,就是数字从大到小的一个动画,但是当我设置要new PropertyPath("XXXXXXX")的时候却报了标题的异常,各种报错.百度了好久也 ...

  10. Junit mockito解耦合测试

    Mock测试是单元测试的重要方法之一. 1.相关网址 官网:http://mockito.org/ 项目源码:https://github.com/mockito/mockito api:http:/ ...