码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 算法学习:LeetCode-593. 有效的正方形


    1.题目

    给定2D空间中四个点的坐标 p1, p2, p3 和 p4,如果这四个点构成一个正方形,则返回 true 。

    点的坐标 pi 表示为 [xi, yi] 。输入 不是 按任何顺序给出的。

    一个 有效的正方形 有四条等边和四个等角(90度角)。

    来源:力扣(LeetCode)
    链接:https://leetcode.cn/problems/valid-square

    2.解题思路

            需要注意的是四个点顺序是任意给出的,所以我们不知道那两个点组成的是对角线。

            但是我们可以算出4个点组成的一共6条边的长度,排序后,最长的是对角线。

            此时只需判断前四个边长是否相等,对角线长度是否相等即可判断(只有正方形的四边相等且对角线长度相等)

    3.代码

    1. class Solution {
    2. public:
    3. long distance(vector<int>& p1, vector<int>& p2){
    4. return pow(p1[0]-p2[0],2)+pow(p1[1]-p2[1],2);
    5. }
    6. public:
    7. bool validSquare(vector<int>& p1, vector<int>& p2, vector<int>& p3, vector<int>& p4) {
    8. if(p1[0]==p2[0] and p1[1]==p2[1]) return false;
    9. vector<int>L(6);
    10. L[0]=distance(p1,p3);
    11. L[1]=distance(p1,p4);
    12. L[2]=distance(p2,p3);
    13. L[3]=distance(p2,p4);
    14. L[4]=distance(p3,p4);
    15. L[5]=distance(p1,p2);
    16. sort(L.begin(),L.end());
    17. return L[0]==L[3] and L[5]==L[4];//只需判断四条边中的第一条和最后一条是否相等即可
    18. }
    19. };
  • 相关阅读:
    线性模型(穷举法实现)
    深度学习:手写反向传播算法(BackPropagation)与代码实现
    ANSYS Maxwell 3D线圈磁场仿真分析
    中级宏观经济学复习范围(马工程)
    find 与 cp 命令组合使用
    外包干了2年,彻底废了...
    区块链基本概念学习笔记
    极客日报:达摩院实现全球最大AI预训练模型;苹果3nm芯片或将2023年问世;微软官宣加入JCP计划
    【每日OJ —— 225.用队列实现栈(队列)】
    刺激的8月!字节三面鞭尸/嘴贱痛失腾讯offer,想要个offer这么难吗
  • 原文地址:https://blog.csdn.net/qq_44635691/article/details/126064784
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号