题意:

有一个正方形区域,

要求支持两个操作:

1、放置三角形,给定放置方向(有4个方向,直角边与坐标轴平行),直角顶点坐标,边长

2、查询一个点被覆盖了多少次

1<=正方形区域边长n<=5000

1<=询问数<=10^5

保证输入合法,三角形被正方形区域完全包含。

题解:

嗯这是一道数据结构题…

一开始我想起来之前做过但没做出来的一道三角形修改三角形查询的分块题…

然后…GEOTCBRL说,是k-d tree呀,CF上面有标程代码长度限制的…

然而我并不会用k-d tree做这个…

于是想起来ACM2015合肥区现场赛的一道题The Shields…

这题可以用和那题类似的方法解决。

树状数组套树状数组(改段求点型)

可以采用三个这样的嵌套树状数组,维护以下信息:

1、矩形区域的值

2、直角朝向左下的三角形区域的值

3、直角朝向左上的三角形区域的值

有了这三种信息就可以很容易的容斥出任意一个方向的三角形区域的值

(用有公共锐角的两个相似的三角形区域相减得到一个直角梯形区域)

(然后和矩形区域作差可以得到三角形区域)

如何实现维护三角形的树状数组?

我们知道树状数组维护的是一种“前缀和”,

那么我们只要把求前缀和的坐标进行一下变换就可以了。

具体来说,

树状数组1:把点映射到(i,j)的前缀和

树状数组2:把点映射到(-i,i+j)的前缀和

树状数组3:把点映射到(i,j-i)的前缀和

然后用相同的办法就可以处理了。

然后因为我为了处理方便,把索引可能出现坐标的位置都平移到正整数位置,所以树状数组开多了几倍。

于是空间有点紧。这题可以离线下来对三个树状数组分别统计答案,同一时刻就只需要一个树状数组了。

(难得地一次AC…在CF上跑得还是第二快的…十分高兴w)

 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#include <cstdio>
#include <cstring>
#include <algorithm>
#define lb(x) ((x)&(-(x)))
using namespace std;
inline int read()
{
int s = ; char c; while((c=getchar())<'0'||c>'9');
do{s=s*+c-'0';}while((c=getchar())>='0'&&c<='9');
return s;
}
const int N = , NQ = ;
int n,n3,tot,ans[NQ],dra[NQ],tia[NQ],tja[NQ],lena[NQ];
bool isc[NQ],is2[NQ];
struct tra
{
int a[N*];
void add(int p,int v){ while(p>) a[p]+=v, p-=lb(p); }
int query(int p){ int s=; while(p<=n3) s+=a[p], p+=lb(p); return s; }
};
struct trb
{
tra a[N];
void add(int p,int p2,int v){ while(p>) a[p].add(p2,v), p-=lb(p); }
int query(int p,int p2){ int s=; while(p<=n) s+=a[p].query(p2), p+=lb(p); return s; }
}tr;
int main()
{
int i,j,Q;
n = read(), n3 = n*, Q = read();
for(i=;i<=Q;i++)
{
if(isc[i]=(read()&)) dra[i] = read(), tja[i] = read(), tia[i] = read(), lena[i] = read()+;
else tja[i] = read(), tia[i] = read();
}
for(i=;i<=Q;i++)
{
if(isc[i])
{
int dr = dra[i], ti = tia[i], tj = tja[i], len = lena[i];
int ti1,tj1,ti2,tj2,v1,v2;
switch(dr)
{
case : ti1=ti+len-,tj1=tj-,v1=-; ti2=ti-,tj2=tj-,v2=; break;
case : ti1=ti,tj1=tj-,v1=-; ti2=ti-len,tj2=tj-,v2=; break;
case : ti1=ti+len-,tj1=tj,v1=; ti2=ti-,tj2=tj,v2=-; break;
case : ti1=ti,tj1=tj,v1=; ti2=ti-len,tj2=tj,v2=-; break;
}
tr.add(ti1,tj1+n,v1);
tr.add(ti2,tj2+n,v2);
}
else ans[i] += tr.query(tia[i],tja[i]+n);
}
memset(tr.a,,sizeof tr.a);
for(i=;i<=Q;i++)
{
if(isc[i])
{
int dr = dra[i], ti = tia[i], tj = tja[i], len = lena[i];
int ti1,tj1,ti2,tj2,v1,v2;
switch(dr)
{
case : ti1=ti,tj1=tj+len-,v1=; ti2=ti+len,tj2=tj-,v2=-; break;
case : ti1=ti+,tj1=tj-len-,v1=; ti2=ti-len+,tj2=tj-,v2=-; break;
default: continue;
}
tr.add(n-ti1+,ti1+tj1,v1);
tr.add(n-ti2+,ti2+tj2,v2);
}
else ans[i] += tr.query(n-tia[i]+,tia[i]+tja[i]);
}
memset(tr.a,,sizeof tr.a);
for(i=;i<=Q;i++)
{
if(isc[i])
{
int dr = dra[i], ti = tia[i], tj = tja[i], len = lena[i];
int ti1,tj1,ti2,tj2,v1,v2;
switch(dr)
{
case : ti1=ti,tj1=tj+len-,v1=; ti2=ti-len,tj2=tj-,v2=-; break;
case : ti1=ti+len-,tj1=tj-,v1=-; ti2=ti-,tj2=tj-len-,v2=; break;
default: continue;
}
tr.add(ti1,tj1-ti1+n,v1);
tr.add(ti2,tj2-ti2+n,v2);
}
else ans[i] += tr.query(tia[i],tja[i]-tia[i]+n);
}
for(i=;i<=Q;i++) if(!isc[i]) printf("%d\n",ans[i]);
return ;
}

Bubble Cup 8 finals I. Robots protection (575I)的更多相关文章

  1. Bubble Cup 11 - Finals [Online Mirror, Div. 1]题解 【待补】

    Bubble Cup 11 - Finals [Online Mirror, Div. 1] 一场很好玩的题啊! I. Palindrome Pairs 枚举哪种字符出现奇数次. G. AI robo ...

  2. Bubble Cup 12 - Finals Online Mirror, unrated, Div. 1

    Bubble Cup 12 - Finals Online Mirror, unrated, Div. 1 C. Jumping Transformers 我会状压 DP! 用 \(dp[x][y][ ...

  3. codeforce1046 Bubble Cup 11 - Finals 题解

    比赛的时候开G开了3h结果rose说一句那唯一一个AC的是羊的心态就崩了.. 这套题感觉质量挺好然后就back了下 A: AI robots 有三个限制条件:相互能够看见和智商的差.使用主席树,可以维 ...

  4. Bubble Cup 8 finals H. Bots (575H)

    题意: 简单来说就是生成一棵树,要求根到每个叶子节点上的路径颜色排列不同, 且每条根到叶子的路径恰有n条蓝边和n条红边. 求生成的树的节点个数. 1<=n<=10^6 题解: 简单计数. ...

  5. Bubble Cup 8 finals G. Run for beer (575G)

    题意: 给定一个带权无向图,每条边的代价为边权/当前速度,每次到达一个新节点,速度都会除以10. 求0号点到n-1号点的最小代价,如果多解输出点数最少的解,输出代价.路径点数.路径经过的点. 1< ...

  6. Bubble Cup 8 finals F. Bulbo (575F)

    题意: 给定初始位置,查询n次区间,每次查询前可以花费移动距离的代价来移动, 查询时需要花费当前位置到区间内最近的点的距离,求最小代价. 1<=n<=5000,1<=所有位置< ...

  7. Bubble Cup 8 finals E. Spectator Riots (575E)

    题意: 一个长宽是100000单位的球场上有很多暴动的观众,每个观众都有一个速度v, 在一秒内,观众会等概率地移动到与原位置的曼哈顿距离<=v的地方(不会移动到界外). 你需要选取三个位置,这三 ...

  8. Bubble Cup 8 finals D. Tablecity (575D)

    题意: (无输入,纯输出题) 一个城市用1000列2行的格子表示,一个小偷藏在城市的某一处. 在每一小时的开始, 在(X, Y)位置的小偷可以移动到 (X - 1, Y), (X + 1, Y),(X ...

  9. Bubble Cup 8 finals C. Party (575C)

    题意: 给定n个人,分两天晚上去夜总会开派对,要求每天恰好有n/2个人去,且每人去的夜总会各不相同. 每个人对不同的晚上不同的夜总会有不同的满意度,求一个方案使得所有人的满意度之和最大. 夜总会数量= ...

随机推荐

  1. 分布式一致性算法--Raft

    前面一篇文章讲了Paxos协议,这篇文章讲它的姊妹篇Raft协议,相对于Paxos协议,Raft协议更为简单,也更容易工程实现.有关Raft协议和工程实现可以参考这个链接https://raft.gi ...

  2. WebServices:WSDL的结构分析

    WSDL(Web Services Description Language,Web服务描述语言)是为描述Web Services发布的XML格式.W3C组织没有批准1.1版的WSDL,但是2.0版本 ...

  3. Linux Shell脚本逻辑操作符简介

    在写程序时,会用到条件判断,测试条件是否成立.很多时候,判断条件是多个的,这个时候需要用到逻辑操作符.shell脚本中常用的有哪些逻辑操作符呢? 1.逻辑与: -a 格式: conditon1 -a ...

  4. MMORPG大型游戏设计与开发(服务器 AI 事件)

    AI中的事件与场景中的事件大致相同,都是由特定的条件触发的.只不过AI的事件与其他事件不同的是,对于AI的事件往往是根据不同的AI类型,和动态的触发条件下才产生的.其实不管AI多么智能,它对应的触发条 ...

  5. sql2008“备份集中的数据库备份与现有的xx数据库不同”解决方法

    http://www.cnblogs.com/huangfr/archive/2012/08/09/2629687.html 因为是在另一台电脑对同名数据库做的备份,用常规方法还原,提示不是相同数据库 ...

  6. Unity中脚本的执行顺序总结(@WhiteTaken)

    (Editor)以上是Unity官方文档中的截图,脚本在被挂载到物体上,会启用Editor的方法Reset. (Initialization)当执行脚本开始,初始化的过程中,依次执行的是Awake-& ...

  7. docker学习(3) 容器的启动过程

    这一节我们来稍微了解下docker原理性的东西 docker run -i -t ubuntu /bin/bash 输入上面这行命令,启动一个ubuntu容器时,到底发生了什么? 大致过程可以用下图描 ...

  8. C#进阶系列——WebApi 跨域问题解决方案:CORS

    前言:上篇总结了下WebApi的接口测试工具的使用,这篇接着来看看WebAPI的另一个常见问题:跨域问题.本篇主要从实例的角度分享下CORS解决跨域问题一些细节. WebApi系列文章 C#进阶系列— ...

  9. 【swift学习笔记】六.访facebook登录页面

    代码最下边有下载地址. 做这个demo的主要心得就是自适应所有的屏幕,要先布局大的框架,再一步一步设置小的细节. 看一下效果 再看一下自动适应所有屏幕的效果: keyboard打开时整个frame上移 ...

  10. 迁移 SQL Server 数据库到 Azure SQL 实战

    最近有个维护的项目需要把 SQL Server 2012 的数据库迁移到 Azure SQL 上去,迁移过程可谓一波三折,故在此分享这次迁移中碰到的点点滴滴,希望对朋友们有所帮助. 文章来源:葡萄城产 ...