POJ 2002 Squares hash求正方形个数
来源:互联网 发布:正版手柄淘宝店 编辑:程序博客网 时间:2024/05/01 18:37
题意:给你n个点 坐标都小于20000 数一下可以组成多少个正方形
思路:借鉴了网上hash的思路 哈希链地址法 把x+y的绝对值相同的放人一个链表里 然后枚举2个点(1条边上的) 推算出另外2个点
另外2点分别是
x1 = a[i].x+(a[i].y-a[j].y);y1 = a[i].y-(a[i].x-a[j].x);
x2 = a[j].x+(a[i].y-a[j].y);y2 = a[j].y-(a[i].x-a[j].x); i ,j 是枚举的2个点的下标
#include <cstdio>#include <cstring>#include <algorithm>#include <cstdlib>using namespace std;const int maxn = 40010;int next[maxn], first[maxn];struct point{int x, y;}a[1010];bool cmp(point a, point b){if(a.x != b.x)return a.x < b.x;return a.y < b.y;}bool ok(int x, int y){int sum = abs(x+y);for(int i = first[sum]; i != -1; i = next[i]){if(a[i].x == x && a[i].y == y)return true;}return false;}int main(){int n;while(scanf("%d", &n) && n){memset(next, -1, sizeof(next));memset(first, -1, sizeof(first));for(int i = 0; i < n; i++){scanf("%d %d", &a[i].x, &a[i].y);}sort(a, a+n, cmp);for(int i = 0; i < n; i++){int sum = abs(a[i].x + a[i].y);next[i] = first[sum];first[sum] = i;}int ans = 0;for(int i = 0; i < n; i++){for(int j = i+1; j < n; j++){int x = a[i].x+(a[i].y-a[j].y);int y = a[i].y-(a[i].x-a[j].x);if(!ok(x, y))continue;x = a[j].x+(a[i].y-a[j].y);y = a[j].y-(a[i].x-a[j].x);if(ok(x, y))ans++;}}printf("%d\n", ans/2);}return 0;}
0 0
- POJ 2002 Squares hash求正方形个数
- Poj 2002 Squares (正方形个数 Hash)
- POJ 2002-Squares(hash拉链法-正方形个数)
- POJ 2002 Squares 求正方形的个数,点哈希
- poj 2202 Squares(求正方形个数)
- POJ 2002 Squares(计算几何 找正方形 hash枚举)
- poj 2002 正方形个数 (对点的hash 存储)
- POJ 2002 Squares Hash
- POJ 2002 Squares -- Hash
- poj 2002 Squares,hash
- POJ 2002 Squares (Hash)
- poj 2002 Squares Hash
- POJ 2002 Squares hash
- poj 2002 Squares(hash)
- poj Squares 2002 (STL&&枚举+转换) 统计正方形的个数
- poj 2002 HASH判断正方形
- poj 2002 Squares (哈希+正方形已知相邻两点求另外两点的坐标)
- POJ 2002 - Squares(hash)
- Protocol Buffers介绍
- 请问如何令对话框中的EDIT控件能接受Enter回车?
- iOS中关于delegate(委托)的使用
- Activity生命周期
- 每日一练------阶乘求和
- POJ 2002 Squares hash求正方形个数
- 机器学习系列(4):混合高斯模型+EM+K-means算法
- 强关联规则是否都是有趣的?
- 百日灸怎么样
- Java中Set的使用
- cocos2d-x 3.0深入了解之一
- 语义化你的HTML 标签
- hdu-1556 Color the ball && nyoj -123 士兵杀敌(四)----------》树状数组
- Unity3d 载入 C++/CLI (托管模式c++) 的动态库(DLL)