ACdream 1127 Base Station (离线查询+树状数组)
题目链接:
http://acdream.info/problem?pid=1127
题目:
移动通信系统中,通信网的建立主要通过基站来完成。
基站可以分为主基站和子基站。子基站和各个移动用户进行连接,子基站必须通过主基站来和外界实现通信。主基站可以覆盖到的范围是一个圆形区域,子基站和主基站的距离小于半径r才能被该主基站覆盖到。半径r由主基站的发射功率确定。
某个区域的移动通信网,包含2个主基站和N个子基站。它们的位置都可以对应到一个整数坐标上。如果子基站至少被一个主基站覆盖,则该子基站是激活的。
现在通信公司在调试设备,它们不停地改变主基站的发射功率,当两个主基站的覆盖半径分别为r1和r2时,需要知道有多少个子基站处于非激活状态。
题解:
对坐标进行转化,子基站对到主基站1(x1,y1)的距离转化为X轴,子基站对到主基站2(x2,y2)的距离转化为Y轴。然后对( 子基站到主基站2(x2,y2)的距离和主基站2的覆盖半径) 进行离散化处理。
然后按X轴进行降序排序,最后将Y轴插入到树状数组中进行维护和离线查询就行了。
复杂度:\(O(m*logn)\)
代码:
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 2e5+100;
const int mod = 1e9+7;
struct node
{
int x,y;
int id;
bool operator < (const node &a) {
return (x == a.x && id < a.id) || (x > a.x);
}
}node[maxn];
int num[maxn];
int ans[maxn];
map<int,int>mp;
int sum[maxn];
int k;
void update(int pos,int val){
// std::cout << "k=" << k << '\n';
while(pos<=k)
{
sum[pos]+=val;
pos += (pos&-pos);
}
}
int query(int pos) {
int res = 0;
while(pos)
{
res += sum[pos];
pos -= (pos&-pos);
}
return res;
}
double distance(double x1,double y1,double x2,double y2)
{
return (double)sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
}
int main(int argc, char const *argv[]) {
int x1,x2,y1,y2;
int n,m,x,y;
while(std::cin >> x1 >> y1 >> x2 >> y2)
{
mp.clear();
k = 0;
std::cin >> n;
for(int i=1;i<=n;i++) {
std::cin >> x >> y;
node[i].x = (int)distance(x,y,x1,y1);
node[i].y = (int)distance(x,y,x2,y2);
node[i].id = -i;
num[k++] = node[i].y;
}
std::cin >> m;
for(int i=1;i<=m;i++) {
std::cin >> node[i+n].x >> node[i+n].y;
node[i+n].id = i;
num[k++] = node[i+n].y;
}
sort(num,num+k);
k = unique(num,num+k)-num;
for(int i=0;i<k;i++) {
mp[num[i]] = i+1;
}
sort(node+1,node+n+m+1);
memset(sum,0,sizeof( sum ));
for(int i=1;i<=n+m;i++) {
int pos = mp[node[i].y];
// std::cout << "now= " <<node[i].x<<" "<< node[i].y <<" " << node[i].id<<" " << pos << '\n';
if(node[i].id < 0) {
update(pos,1);
}
else if(node[i].id >= 1){
ans[node[i].id] = query(k) - query(pos-1);
}
}
for(int i=1;i<=m;i++) {
std::cout << ans[i] << '\n';
}
}
// cerr << "Time elapsed: " << 1.0 * clock() / CLOCKS_PER_SEC << " s.\n";
return 0;
}
ACdream 1127 Base Station (离线查询+树状数组)的更多相关文章
- HDU 4746 莫比乌斯反演+离线查询+树状数组
题目大意: 一个数字组成一堆素因子的乘积,如果一个数字的素因子个数(同样的素因子也要多次计数)小于等于P,那么就称这个数是P的幸运数 多次询问1<=x<=n,1<=y<=m,P ...
- BZOJ1878: [SDOI2009]HH的项链 (离线查询+树状数组)
1878: [SDOI2009]HH的项链 题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1878 Description: HH有一串由 ...
- 【bzoj4540】[Hnoi2016]序列 单调栈+离线+扫描线+树状数组区间修改区间查询
题目描述 给出一个序列,多次询问一个区间的所有子区间最小值之和. 输入 输入文件的第一行包含两个整数n和q,分别代表序列长度和询问数.接下来一行,包含n个整数,以空格隔开,第i个整数为ai,即序列第i ...
- 【loj6041】「雅礼集训 2017 Day7」事情的相似度 后缀自动机+STL-set+启发式合并+离线+扫描线+树状数组
题目描述 给你一个长度为 $n$ 的01串,$m$ 次询问,每次询问给出 $l$ .$r$ ,求从 $[l,r]$ 中选出两个不同的前缀的最长公共后缀长度的最大值. $n,m\le 10^5$ 题解 ...
- hdu-3333 Turing Tree 离线区间+树状数组(区间不同数的和)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3333 题目大意: 给出一数组,以及m个查询区间,每次查询该区间不同数字的和.相同数字只加一次. 解题 ...
- [CF369E]Valera and Queries_离线_树状数组
Valera and Queries 题目链接:codeforces.com/problemset/problem/369/E 数据范围:略. 题解: 这种题,就单独考虑一次询问即可. 我们发现,包括 ...
- bzoj3529(莫比乌斯反演+离线+树状数组)
在你以为理解mobus的时候,苦苦想通过化简公式来降低复杂度时,这题又打了我一巴掌. 看来我并没有理解到acmicpc比赛的宗旨啊. 这么多次查询可以考虑离线操作,使用树状数组单点更新. /***** ...
- bzoj 3110: [Zjoi2013]K大数查询 树状数组套线段树
3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 1384 Solved: 629[Submit][Stat ...
- HDU 4638 Group (2013多校4 1007 离线处理+树状数组)
Group Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ...
随机推荐
- Spring 热点面试题:
1.谈谈你对Springaop的理解? spring用代理类包裹切面,把他们织入到Spring管理的bean中.也就是说代理类伪装成目标类,它会截取对目标类中方法的调用,让调用者对目标类的调用都先变成 ...
- python note #2
This passage will talk about some small but pretty important knowledge points, including using metho ...
- Android学习笔记(23):列表项的容器—AdapterView的子类们
AdapterView的子类的子类ListView.GridView.Spinner.Gallery.AdapterViewFlipper和StackView都是作为容器使用,Adapter负责提供各 ...
- Android上玩玩Hook?
在中国互联网这片弱肉强食的丛林中.封闭抄袭是垄断巨头的通行证.创新是弱小创业者的墓志铭. 了解Hook 还没有接触过Hook技术读者一定会对Hook一词感觉到特别的陌生.Hook英文翻译过来就是&qu ...
- C++对象模型——Inline Functions(第四章)
4.5 Inline Functions 以下是Point class 的一个加法运算符的可能实现内容: class Point { friend Point operator+(const Poin ...
- ElasticSearch 在Hadoop生态圈的位置
它的位置非常清晰,直接贴图. 更详细点,见
- 【深入篇】Andorid中常用的控件及属性
TextView android:autoLink 设置是否当文本为URL链接/email/电话号码/map时,文本显示为可点击的链接.可选值(none/web/email/phone/map/al ...
- Gym 100952 C. Palindrome Again !!
http://codeforces.com/gym/100952/problem/C C. Palindrome Again !! time limit per test 1 second memor ...
- 2017国家集训队作业[agc006e]Rotate 3x3
2017国家集训队作业[agc006e]Rotate 3x3 题意: 给你一个\(3*N\)的网格,每次操作选择一个\(3*3\)的网格,旋转\(180^\circ\).问可不可以使每个位置\(( ...
- canvas:画布
画布有默认宽度,如果要自己设置宽带要写在属性上 列: <canvas id = "myCanvas" width = "600" height = &qu ...