codeforces 425D
题意:给定n<=100000个二维点,并且0<=x,y<=100000,求有多少个平行于坐标轴的正方形
思路:本来想hash的,但是感觉不好弄。。
后来感觉像是分块,最坏的情况就是那种x,y点稠密在一起的情况,并且x与y大致相同的情况下答案最多。。
然后就想到了跟分块很像的暴力。
对于每个点,用vx[x]记录有p.x==x的点的y,用vy[y]记录p.y==y的x
那么对于每个vx[], vy[]排序。。
接着对于每个点我们统计以它为右上角的正方形。。
那么对于每个点(x, y),我们二分查找x处于vy[y]的位置ty,我们二分查找y处于vx[x]的位置tx
那么如果tx<ty,我们直接统计vx[x][0]~vx[x][tx-1]的所有y是否有符合的
每次判断可以通过使用二分查找其他点是否存在。。
如果tx>=ty则统计vy[y][0]~vy[y][ty-1]的所有y是否符合。方法类似。
这样最坏情况下应该跟分块的复杂度差不多吧(不会证明)
code:
#include <bits/stdc++.h>
#define M0(x) memset(x, 0, sizeof(x))
#define MP make_pair
#define PB push_back
#define repf(i, a, b) for (int i = (a); i <= (b); ++i)
using namespace std;
#define x first
#define y second
const int maxn = ;
pair<int, int> p[maxn];
vector<int> vx[maxn], vy[maxn];
int n, m; void solve(){
int mx = , my = ;
repf(i, , n){
scanf("%d%d", &p[i].x, &p[i].y);
mx = max(p[i].x, mx);
my = max(p[i].y, my);
}
repf(i, , mx) vx[i].clear();
repf(i, , my) vy[i].clear();
repf(i, , n){
vx[p[i].x].PB(p[i].y);
vy[p[i].y].PB(p[i].x);
}
repf(i, , mx) sort(vx[i].begin(), vx[i].end());
repf(i, , my) sort(vy[i].begin(), vy[i].end());
int ans = ;
int tx, ty, x, y, t2, t3, d, nx, ny;
repf(i, , n){
x = p[i].x, y = p[i].y;
tx = lower_bound(vx[x].begin(), vx[x].end(), y) - vx[x].begin();
ty = lower_bound(vy[y].begin(), vy[y].end(), x) - vy[y].begin();
if (tx < ty){
t2 = ty;
for (int j = tx-; j >= ; --j){
d = y - vx[x][j];
nx = x - d;
t2 = lower_bound(vy[y].begin(), vy[y].end(), nx) - vy[y].begin();
if (vy[y][t2] == nx){
t3 = lower_bound(vx[nx].begin(), vx[nx].end(), vx[x][j]) - vx[nx].begin();
if (vx[nx][t3] == vx[x][j]) ++ans;
}
}
continue;
}
// t2 = tx;
for (int j = ty-; j >= ; --j){
d = x - vy[y][j];
ny = y - d;
t2 = lower_bound(vx[x].begin(), vx[x].end(), ny) - vx[x].begin();
if (vx[x][t2] == ny){
t3 = lower_bound(vy[ny].begin(), vy[ny].end(), vy[y][j]) - vy[ny].begin();
if (vy[ny][t3] == vy[y][j]) ++ans;
}
}
}
cout << ans << endl;
} int main(){
// freopen("a.in", "r", stdin);
// freopen("a.out", "w", stdout);
while (scanf("%d", &n) != EOF){
solve();
}
return ;
}
codeforces 425D的更多相关文章
- codeforces 425D Sereja and Squares n个点构成多少个正方形
输入n个点,问可以构成多少个正方形.n,xi,yi<=100,000. 刚看题的时候感觉好像以前见过╮(╯▽╰)╭最近越来越觉得以前见过的题偶尔就出现类似的,可是以前不努力啊,没做出来的没认真研 ...
- python爬虫学习(5) —— 扒一下codeforces题面
上一次我们拿学校的URP做了个小小的demo.... 其实我们还可以把每个学生的证件照爬下来做成一个证件照校花校草评比 另外也可以写一个物理实验自动选课... 但是出于多种原因,,还是绕开这些敏感话题 ...
- 【Codeforces 738D】Sea Battle(贪心)
http://codeforces.com/contest/738/problem/D Galya is playing one-dimensional Sea Battle on a 1 × n g ...
- 【Codeforces 738C】Road to Cinema
http://codeforces.com/contest/738/problem/C Vasya is currently at a car rental service, and he wants ...
- 【Codeforces 738A】Interview with Oleg
http://codeforces.com/contest/738/problem/A Polycarp has interviewed Oleg and has written the interv ...
- CodeForces - 662A Gambling Nim
http://codeforces.com/problemset/problem/662/A 题目大意: 给定n(n <= 500000)张卡片,每张卡片的两个面都写有数字,每个面都有0.5的概 ...
- CodeForces - 274B Zero Tree
http://codeforces.com/problemset/problem/274/B 题目大意: 给定你一颗树,每个点上有权值. 现在你每次取出这颗树的一颗子树(即点集和边集均是原图的子集的连 ...
- CodeForces - 261B Maxim and Restaurant
http://codeforces.com/problemset/problem/261/B 题目大意:给定n个数a1-an(n<=50,ai<=50),随机打乱后,记Si=a1+a2+a ...
- CodeForces - 696B Puzzles
http://codeforces.com/problemset/problem/696/B 题目大意: 这是一颗有n个点的树,你从根开始游走,每当你第一次到达一个点时,把这个点的权记为(你已经到过不 ...
随机推荐
- perl脚本基础总结
1. 单引号字符串中的\n不会被当做换行符处理. 如:'\'\\' --> '\ . 2. 双引号 字符串联 "Hello"."World" ...
- leetcode 136
136. Single Number Given an array of integers, every element appears twice except for one. Find that ...
- 码农谷 找出N之内的所有完数
题目描述 一个数如果恰好等于它的因子之和,这个数就称为"完数". 例如,6的因子为1.2.3,而6=1+2+3,因此6是"完数". 编程序找出N之内的所有完数, ...
- ApexSql Log 2014.04.1133破解版&补丁
已上传最新的2016版本,请移步: http://www.cnblogs.com/gsyifan/p/ApexSql_Log_2016_Crack.html 状态不好,鬼使补差的跑到服务器上updat ...
- mysql Can't connet MySQL server to '@localhost'
10063/10060/10038好像都能解决 mysql -nt -remove mysql -nt install
- CSS盒子模型学习记录2
参考:http://www.blueidea.com/tech/web/2007/4545_2.asp 代码试验: html代码: <!DOCTYPE html PUBLIC "-// ...
- Hadoop HDFS编程 API入门系列之简单综合版本1(四)
不多说,直接上代码. 代码 package zhouls.bigdata.myWholeHadoop.HDFS.hdfs4; import java.io.IOException; import ja ...
- html中的块元素(Block)和内联元素(Inline)(转)
我们首先要了解,所有的html元素,都要么是块元素(block).要么是内联元素(inline).下面了解一下块元素.内联元素各自的特点: 块元素(block)的特点: 1.总是在新行上开始:2.高度 ...
- 通过反射向将EF的实体映射配置加入到实体模型中
public AdminDbContext() : base("MemberDbContext") { //不使用代理创建导航属性,避免WCF序列化错误 Configuration ...
- Cannot assign to 'self' outside of a method in the init family
今天在重写父类的init方法时报错如下: error:Cannot assign to 'self' outside of a method in the init family 这种问题以前从来没有 ...