PKU 2002 Squares(二维点哈希+平方求余法+链地址法)
题目大意:原题链接
给定平面上的N个点,求出这些点一共可以构成多少个正方形。
解题思路:
若正方形为ABCD,A坐标为(x1, y1),B坐标为(x2, y2),则很容易可以推出C和D的坐标。对于特定的A和B坐标,C和D可以在线段AB的上面或者下面,即有两种情况。
根据构造三角形全等可以得知(很简单,注意下细节,不要把坐标弄混就行)
CD在AB上面x3=x2+(y1-y2),y3=y2+(x2-x1); x4=x1+(y1-y2),y4=y1+(x2-x1);
CD在AB下面x3=x2-(y1-y2),y3=y2-(x2-x1); x4=x1-(y1-y2),y4=y1-(x2-x1);
因此只需要枚举点A和点B,然后计算出两种对应的C和D的坐标,判断是否存在即可。这样计算完之后得到的答案是正确答案的4倍,因为正方形的4条边都枚举了,所以答案要右移两位
Insert(int x,int y)采用平方求余法构造哈希函数,链地址法(用类邻接表法实现)处理冲突进行哈希
Judge(int x,int y)通过查找判断CD两点是否同时存在,即能判断是否可以构成正方形
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
const int maxn=;
const int N=;
int px[maxn],py[maxn];
struct Node
{
int x,y;
int next;
}node[N];
long long ans;
int n,cur,Hash[N]; void Insert(int x,int y)
{
int h=(x*x+y*y)%N;
node[cur].x=x;
node[cur].y=y;
node[cur].next=Hash[h];
Hash[h]=cur++;
}
bool Judge(int x,int y)
{
int h=(x*x+y*y)%N;
int next=Hash[h];
while(next!=-){
if(x==node[next].x&&y==node[next].y)
return true;
next=node[next].next;
}
return false;
} int main()
{
while(cin>>n,n){
memset(Hash,-,sizeof(Hash));
cur=,ans=;
for(int i=;i<n;i++){
cin>>px[i]>>py[i];
Insert(px[i],py[i]);
}
for(int i=;i<n;i++){//先枚举考虑CD在AB上面
for(int j=i+;j<n;j++){
int x3=px[j]+(py[i]-py[j]);
int y3=py[j]+(px[j]-px[i]);
int x4=px[i]+(py[i]-py[j]);
int y4=py[i]+(px[j]-px[i]);
if(Judge(x3,y3)&&Judge(x4,y4)) ans++;
}
}
for(int i=;i<n;i++){//再枚举考虑CD在AB下面
for(int j=i+;j<n;j++){
int x3=px[j]-(py[i]-py[j]);
int y3=py[j]-(px[j]-px[i]);
int x4=px[i]-(py[i]-py[j]);
int y4=py[i]-(px[j]-px[i]);
if(Judge(x3,y3)&&Judge(x4,y4)) ans++;
}//要判断C点和D点同时存在才能构成正方形
}
ans>>=;
printf("%lld\n",ans);
}
}
PKU 2002 Squares(二维点哈希+平方求余法+链地址法)的更多相关文章
- java 解决Hash(散列)冲突的四种方法--开放定址法(线性探测,二次探测,伪随机探测)、链地址法、再哈希、建立公共溢出区
java 解决Hash(散列)冲突的四种方法--开放定址法(线性探测,二次探测,伪随机探测).链地址法.再哈希.建立公共溢出区 标签: hashmaphashmap冲突解决冲突的方法冲突 2016-0 ...
- Java 二维数组,排序、切换顺序,查表法二进制十进制,这班查找、排序(冒泡、选择)、遍历,获取最大小值(4)
Java 二维数组,排序.切换顺序,查表法二进制十进制,折半查找.排序(冒泡.选择).遍历,获取最大小值(4)
- C# Dictionary源码剖析---哈希处理冲突的方法有:开放定址法、再哈希法、链地址法、建立一个公共溢出区等
C# Dictionary源码剖析 参考:https://blog.csdn.net/exiaojiu/article/details/51252515 http://www.cnblogs.com/ ...
- SWUST OJ 1012哈希表(链地址法处理冲突)
哈希表(链地址法处理冲突) 1000(ms) 10000(kb) 2676 / 6911 采用除留余数法(H(key)=key %n)建立长度为n的哈希表,处理冲突用链地址法.建立链表的时候采用尾插法 ...
- URAL - 1486 Equal Squares 二维哈希+二分
During a discussion of problems at the Petrozavodsk Training Camp, Vova and Sasha argued about who o ...
- poj-3739. Special Squares(二维前缀和)
题目链接: I. Special Squares There are some points and lines parellel to x-axis or y-axis on the plane. ...
- UVA - 11019 Matrix Matcher (二维字符串哈希)
给你一个n*m的矩阵,和一个x*y的模式矩阵,求模式矩阵在原矩阵中的出现次数. 看上去是kmp在二维情况下的版本,但单纯的kmp已经无法做到了,所以考虑字符串哈希. 类比一维情况下的哈希算法,利用容斥 ...
- POJ 2002 Squares 解题报告(哈希 开放寻址 & 链式)
经典好题. 题意是要我们找出所有的正方形.1000点,只有枚举咯. 如图,如果我们知道了正方形A,B的坐标,便可以推测出C,D两点的坐标.反之,遍历所有点作为A,B点,看C,D点是否存在.存在的话正方 ...
- Java解决Hash(散列)冲突的四种方法--开放地址法(线性探测,二次探测,伪随机探测)、链地址法、再哈希、建立公共溢出区
最近时间有点紧,暂时先放参考链接了,待有时间在总结一下: 查了好多,这几篇博客写的真心好,互有优缺点,大家一个一个看就会明白了: 参考 1. 先看这个明白拉链法(链地址法),这个带源码,很好看懂,只不 ...
随机推荐
- H&M
H&M于1947年由Erling Persson在瑞典创立.如今,H&M在全世界1500 多个专卖店销售服装.配饰与化妆品.位于瑞典市Stora Gatan大街的老H&M店是世 ...
- Hadoop1.2.1 配置文件详解
首先我们先回顾一下Hadoop的一些概念: Apache Hdoop 1.x 组成 NameNode(元数据服务器) Secondary NameNode(辅助元数据服务器) JobTracker(任 ...
- axios如何进行跨域以及对返回格式为回调函数字符串的处理
自从vue2.0开始不对vue-resouce进行维护了,转而用axios进行代替,axios的官方文档写的很详细,附上链接一枚:http://www.jianshu.com/p/df464b26ae ...
- Java之自动拆装箱
顾名思义,自动拆装箱就是将基本类型和包装类进行自动的互相转换. JDK5.0后,将自动装箱/拆箱引Java中. 自动装箱的过程:每当需要一种类型的对象时,这种基本类型就自动地封装到与它相同类型的包装中 ...
- 160315、mybatis批量删除
<deleteid="deleteCTQ" parameterType="java.lang.String"> DELETE FROM sqm_pr ...
- Jmeter--压测dubbo接口
Dubbo Interface Demo:https://blog.csdn.net/qi_lin7/article/details/53759528 Demo2:https://blog.csdn. ...
- 浏览器加载不上css,样式走丢
来自:http://www.cnblogs.com/crizygo/p/5466444.html 问题描述:使用eclipse修改样式文件,浏览器的页面一时显示一时不显示,最后直接没有加载最新的css ...
- Javascript 香港身份证号校验
<!DOCTYPE html> <html> <head> <title>香港身份证校验码计算</title> </head> ...
- css如何引入外部字体?
第一步,在CSS中引入字体并给名字取一个合适的名字,如下 1 2 3 4 5 6 7 @font-face { /* font-properties */ font-family: p ...
- Boss Group Worker Group NioEventLoopGroup
宜人贷蜂巢API网关技术解密之Netty使用实践 - honeycomb2017的博客 - CSDN博客 https://blog.csdn.net/honeycomb2017/article/det ...