1. Job Roadmap
  2. Home
  3. Problem Set
  4. codenotelist
  5. Forum
  6. course
  7. Shore Share Sessions
  8. Record
  1. Login
  2. Sign Up
  3. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
    ZhContent TextSol AI分析

暴力

已知正方形的一条边是可以确定正方形,假设两个点是(a1,a2),(b1,b2),那么可以确定\\ c1=a1+(a2-b2),c2=a2-(a1-b1)\\ d1=b1+(a2-b2),d2=b2-(a1-b1)\\ 或者\\ c1=a1+(a2-b2),c2=a2-(a1-b1);\\ d1=b1+(a2-b2),d2=b2-(a1-b1);\\ 因此一个正方形会被计算八遍,枚举任意两个点计算出来的结果/8就是答案,这个正方形可以二分也可以哈希,看到点的横坐标纵坐标范围很小考虑n4枚举任意两个点即可

代码如下

P3101.构成正方形的数量(100分)

    1000ms Tried: 224 Accepted: 48 Difficulty: 5 所属公司 : 华为od
    算法与标签>暴力枚举

题目内容

输入NNN个互不相同的二维整数坐标,求这NNN个坐标可以构成的正方形数量。(内积只为零的的两个向量垂直)

输入描述

第一行输入为NNN,NNN代表坐标数量,NNN为正整数。

N≤100N≤100N≤100

之后的NNN行输入为坐标x,yx,yx,y 以空格分隔,x,yx,yx,y为整数

−10≤x,y≤10-10≤x,y≤10−10≤x,y≤10

输出描述

输出可以构成的正方形数量

样例1

输入

 3
 1 3
 2 4
 3 1

输出

0

说明

3个点不足以构成正方形

样例2

输入

4
0 0
1 2
3 1
2 -1

输出

1

说明

此4点可构成正方形

登录后即可使用 AI 分析。

模式
倒计时时长
:

最长 10 小时 59 分;应用后按此时长重新开始。

提示:点击提交记录在左侧题面区域查看详情
题库
AI分析设置
留空使用官方API Key,每天有次数限制(自定义API Key仅限会员和管理员使用,不限次数)
会员和管理员可切换模型;切到 Kimi/智谱/通义/豆包时需填写对应供应商 API Key
升级会员,可将运行与提交冷却时间缩短至 1 秒起

Status

  • Judging Queue
  • Service Status

Development

  • Open Source

Support

  • Help
  • Contact Us

About

  • About
  • Privacy
  • Terms of Service
  • Copyright Complaint
  1. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
  2. Legacy mode
  3. Theme
    1. Light
    2. Dark
  1. 京ICP备2025123107号-1
  2. Worker 1, 34ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

请使用微信扫描下方二维码完成注册

Forgot password or username?