poj 3432 --直接看上一篇2002吧。

本文介绍了一种通过哈希表实现的点集运算算法,用于解决给定平面上的点集问题。该算法首先将所有点存储在一个哈希表中,然后通过两重循环遍历每两个点,计算出另外两个可能存在的点,并检查这两个点是否存在于哈希表中。如果存在,则说明这四个点可以构成特定的几何形状,计数器加一。最终输出满足条件的几何形状数量。
部署运行你感兴趣的模型镜像

同一个题目,不一样的形式,见上一篇2002的分析:

#include <iostream>
using namespace std;

struct Node
{
	int x,y;
	Node * next;
}node[40001];

int n;
int cod[2005][2];
int Find(int x, int y)
{
	int key = (x * x + y * y) % 40001;
	Node *tmp = &node[key];
	while (tmp->next != NULL)
	{
		tmp = tmp->next;
		if (tmp->x == x && tmp->y == y)
		{
			return 1;
		}
	}
	return 0;
}
int main()
{
	while (scanf("%d", &n) != EOF/*&& n*/)
	{
		memset(node, 0, sizeof(node));
		Node * point;
		for (int i = 1; i <= n; ++ i) 
		{
			point = new Node;
			scanf("%d %d", &cod[i][0], &cod[i][1]);
			point->x = cod[i][0];
			point->y = cod[i][1];
			point->next = NULL;

			int key = (cod[i][0] * cod[i][0] + cod[i][1] * cod[i][1]) % 40001;
			Node *tmp = &node[key];
			while (tmp->next != NULL)
			{
				tmp = tmp->next;
			}
			tmp->next = point;
		}

		int ans = 0;
		int x1,y1,x2,y2;
		for (int i = 1; i < n; ++ i)
		{
			for (int j = i + 1; j <= n; ++ j)
			{
				//two points on one side
				x1 = cod[i][0] + (cod[i][1] - cod[j][1]);
				y1 = cod[i][1] - (cod[i][0] - cod[j][0]);
				x2 = cod[j][0] + (cod[i][1] - cod[j][1]);
				y2 = cod[j][1] - (cod[i][0] - cod[j][0]);
				if (Find(x1,y1) && Find(x2,y2))
				{
					ans ++;
				}
				//
				x1 = cod[i][0] - (cod[i][1] - cod[j][1]);
				y1 = cod[i][1] + (cod[i][0] - cod[j][0]);
				x2 = cod[j][0] - (cod[i][1] - cod[j][1]);
				y2 = cod[j][1] + (cod[i][0] - cod[j][0]);
				if (Find(x1,y1) && Find(x2,y2))
				{
					ans ++;
				}
			}
		}
		printf("%d\n", ans / 4);
	}
	return 0;
}


您可能感兴趣的与本文相关的镜像

ACE-Step

ACE-Step

音乐合成
ACE-Step

ACE-Step是由中国团队阶跃星辰(StepFun)与ACE Studio联手打造的开源音乐生成模型。 它拥有3.5B参数量,支持快速高质量生成、强可控性和易于拓展的特点。 最厉害的是,它可以生成多种语言的歌曲,包括但不限于中文、英文、日文等19种语言

下载前可以先看下教程 https://pan.quark.cn/s/16a53f4bd595 小天才电话手表刷机教程 — 基础篇 我们将为您简单的介绍小天才电话手表新机型的简单刷机以及玩法,如adb工具的使用,magisk的刷入等等。 我们会确保您看完此教程后能够对Android系统有一个最基本的认识,以及能够成功通过magisk root您的手表,并安装您需要的第三方软件。 ADB Android Debug Bridge,简称,在android developer的adb文档中是这么描述它的: 是一种多功能命令行工具,可让您与设备进行通信。 该命令有助于各种设备操作,例如安装和调试应用程序。 提供对 Unix shell 的访问,您可以使用它在设备上运行各种命令。 它是一个客户端-服务器程序。 这听起来有些难以理解,因为您也没有必要去理解它,如果您对本文中的任何关键名词产生疑惑或兴趣,您都可以在搜索引擎中去搜索它,当然,我们会对其进行简单的解释:是一款在命令行中运行的,用于对Android设备进行调试的工具,并拥有比一般用户以及程序更高的权限,所以,我们可以使用它对Android设备进行最基本的调试操作。 而在小天才电话手表上启用它,您只需要这么做: - 打开拨号盘; - 输入; - 点按打开adb调试选项。 其次是电脑上的Android SDK Platform-Tools的安装,此工具是 Android SDK 的组件。 它包括与 Android 平台交互的工具,主要由和构成,如果您接触过Android开发,必然会使用到它,因为它包含在Android Studio等IDE中,当然,您可以独立下载,在下方选择对应的版本即可: - Download SDK Platform...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值