Bestcoders
Senior's Fish
Time Limit: 14000/7000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 242 Accepted Submission(s): 50
y-axis. The fishes can be seen as points. Sometimes the fishes will enter the net, and sometimes they will leave the net. So, Xuejiejie doesn't know the appropriate time to draw the net in when she will get as many fishes as possible.
Xuejiejie assigns each fish with a number, from 1 to n, n being
the total number. There are 2 types of movements of the fishes:
1 l r d : the fishes index between the interval [l,r] moved towards the x-axis for length d (For example , if a fish's current position is (x,y) ,
after moving , its position will change to (x+d,y).
)
2 l r d : the fishes index between the interval [l,r] moved towards the y-axis for length d (For example , if a fish's current position is (x,y),
after moving , its position will change to (x,y+d).
)
And sometimes Xuejiejie will ask you some questions.
indicates the number of test cases.
In each case:
The first line includes an integer n indicating
the total number of fish.
The second line includes 4 integers x1,y1。x2,y2,indicating
the position of the fishing net. (x1,y1) means
the lower-left position, and (x2,y2) means
the top-right position.
The next n lines: each line includes x[i],y[i];
means the fish i's initial position.
The next line includes an integer m.
The next m lines
describe the events you have to deal with.
In each line the first integer is c (1≤c≤3),
which indicates the type of events.
1 l r d : the fish index between the interval [l。r] moved towards the x-axis for length d
2 l r d : the fish index between the interval [l,r] moved towards the y-axis for length d
3 l r : query the number of the fish index between the interval [l,r] which are in the net(including the one in the border)
1≤n,m≤100000, 1≤l≤r≤n. 1≤d≤109, x1≤x2, y1≤y2。
Ensure that any time all involved coordinate values in the range of[−109,109]。
For each type 3 events, output a integer which means the answer.
1
5
1 1 5 5
1 1
2 2
3 3
4 4
5 5
3
3 1 5
1 2 4 2
3 1 5
5
4
hujie | We have carefully selected several similar problems for you: 5287 pid=5286" target="_blank" style="color:rgb(26,92,200); text-decoration:none">5286 pid=5284" target="_blank" style="color:rgb(26,92,200); text-decoration:none">5284 pid=5278" target="_blank" style="color:rgb(26,92,200); text-decoration:none">5278
题解:用线段树维护每一个点左下角内鱼的数目。由于渔网有四条边,依据限制条件的不同,须要维护四颗线段树,其限制条件分别不能从x or y 轴越过,否则该鱼不參与计数,设ans[0 ~ 3]分别为渔网右上角、左上角、右下角、左下角四个点左下方鱼的数目,则答案为: Ans = ans[0] - ans[1] - ans[2] + ans[3].
代码 I : (第一个写的。为超时版本号, 正在努力改动)
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm> using namespace std;
#define INF 0x7ffffff
#define eps 1e-8
#define maxn 100000 + 10
#define lson L, mid, rt<<1
#define rson mid+1, R, rt<<1|1 int X[4], Y[4], x[2], y[2];
int n, m;
int xx[maxn], yy[maxn]; struct Node
{
int sum, mx, my, addx, addy; ///addx addy 相当于lazy标记
}T[4][maxn<<2]; void Pushup(int k, int rt)
{
int l = rt<<1, r = rt<<1|1;
T[k][rt].sum = T[k][l].sum + T[k][r].sum;
T[k][rt].mx = max(T[k][l].mx, T[k][r].mx);
T[k][rt].my = max(T[k][l].my, T[k][r].my);
} void Pushdown(int k, int rt)
{
int l = rt<<1, r = rt<<1|1;
int t1 = T[k][rt].addx, t2 = T[k][rt].addy; T[k][l].addx += t1, T[k][r].addx += t1;
T[k][l].addy += t2, T[k][r].addy += t2;
T[k][l].mx += t1, T[k][r].mx += t1;
T[k][l].my += t2, T[k][r].my += t2; T[k][rt].addx = T[k][rt].addy = 0;
} void Bulid(int k, int L, int R, int rt) ///递归构造线段树
{
T[k][rt].addx = T[k][rt].addy = 0;
if(L == R)
{
if(xx[L]<=X[k] && yy[L]<=Y[k])
{
T[k][rt].sum = 1;
T[k][rt].mx = xx[L], T[k][rt].my = yy[L];
}
else
{
T[k][rt].sum = 0;
T[k][rt].mx = T[k][rt].my = -INF;
}
return ;
}
int mid = (L+R)>>1;
Bulid(k, lson);
Bulid(k, rson);
Pushup(k, rt);
} void Update(int k, int flag, int l, int r, int d, int L, int R, int rt)
{
if(l<=L && r>=R)
{
if(flag) /// 1 -- x
{
T[k][rt].addx += d, T[k][rt].mx += d;
if(T[k][rt].mx <= X[k])
return ;
}
else /// 0 -- y
{
T[k][rt].addy += d, T[k][rt].my += d;
if(T[k][rt].my <= Y[k])
return ;
}
if(L == R)
{
T[k][rt].sum = 0;
T[k][rt].mx = T[k][rt].my = -INF;
return ;
}
}
int mid = (L+R)>>1;
if(T[k][rt].addx || T[k][rt].addy) Pushdown(k, rt);
if(r <= mid) Update(k, flag, l, r, d, lson);
else if(l > mid) Update(k, flag, l, r, d, rson);
else
{
Update(k, flag, l, mid, d, lson);
Update(k, flag, mid+1, r, d, rson);
}
Pushup(k, rt);
} int Query(int k, int l, int r, int L, int R, int rt)
{
if(l<=L && r>=R)
return T[k][rt].sum;
int mid = (L+R)>>1;
if(T[k][rt].addx || T[k][rt].addy) Pushdown(k, rt);
if(r <= mid) Query(k, l, r, lson);
else if(l > mid) Query(k, l, r, rson);
else
return Query(k, l, mid, lson) + Query(k, mid+1, r, rson);
} int ans[4]; int main()
{
int T;
scanf("%d", &T);
while(T--)
{
scanf("%d", &n);///
scanf("%d%d%d%d", &x[0], &y[0], &x[1], &y[1]);
X[0] = x[1], Y[0] = y[1];
X[1] = x[0]-1, Y[1] = y[1];
X[2] = x[1], Y[2] = y[0]-1;
X[3] = x[0]-1, Y[3] = y[0]-1;
for(int i=1; i<=n; i++)
scanf("%d%d", &xx[i], &yy[i]);/// for(int i=0; i<4; i++)
Bulid(i, 1, n, 1); scanf("%d", &m);///
for(int i=0; i<m; i++)
{
int t, l, r, d;
scanf("%d%d%d", &t, &l, &r);
if(t < 3) scanf("%d", &d);
if(t == 1)
{
for(int i=0; i<4; i++)
Update(i, 1, l, r, d, 1, n, 1);
}
else if(t == 2)
{
for(int i=0; i<4; i++)
Update(i, 0, l, r, d, 1, n, 1);
}
else
{
for(int i=0; i<4; i++)
ans[i] = Query(i, l, r, 1, n, 1);
printf("%d\n", ans[0] - ans[1] - ans[2] + ans[3]);
}
}
}
return 0;
} /* 2 5
1 1 5 5
1 1
2 2
3 3
4 4
5 5
3
3 1 5
1 2 4 2
3 1 5 3
1 1 5 5
1 5
2 5
3 5
4
2 2 5 1
3 1 1
3 1 2
3 1 5 */
Bestcoders的更多相关文章
随机推荐
- cat /proc/maps 进程内存映射【转】
转自:http://blog.csdn.net/fisher_jiang/article/details/5063852 proc/<PID>/maps查看进程的虚拟地址空间是如何使用的. ...
- hdu 2544(SPFA)
最短路 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- Java屌炸天学习路线图
第一阶段:Java基础篇 编号 课程 课程目录 打包下载地址 讲师 01 J2SE(40课时) http://www.java1234.com/zy001.html http://pa ...
- POJ 3620 Avoid The Lakes【DFS找联通块】
Avoid The Lakes Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6826 Accepted: 3637 D ...
- HttpRunner 接口自动化测试进阶
前面说到了httprunner的安装与简单使用,参见: https://www.cnblogs.com/chengtch/p/8735160.html 这里我们介绍一下通过调试源码的方式来做接口测试: ...
- 「kuangbin带你飞」专题十五 数位DP
传送门 A.CodeForces - 55D Beautiful numbers 题意 一个正整数是 漂亮数 ,当且仅当它能够被自身的各非零数字整除.我们不必与之争辩,只需计算给定范围中有多少个漂亮数 ...
- 【bzoj3173】【Tjoi2013】【最长上升子序列】treap+dp二分优化
[pixiv] https://www.pixiv.net/member_illust.php?mode=medium&illust_id=61560361 向大(hei)佬(e)实力学(di ...
- [POI2008]Mirror Trap
题目大意: 一个$n(n\le10^5)$个顶点的格点多边形,每条边平行于网格线,每个角度数均为$90^\circ$或$270^\circ$,周长小于$3\times10^5$,每个顶点可以安装激光发 ...
- iOS Undefined symbols for architecture arm64解决办法
Undefined symbols for architecture arm64: "_OBJC_CLASS_$_YYCache", referenced from: ...
- 操作系统/etc/hosts文件配置
windows对应 C:\Windows\system32\drivers\etc\hosts linux: /etc/hosts Hosts - The static table lookup fo ...