码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【每日一题Day44】LC1779找到最近的相同X和相同Y的点 | 模拟


    找到最近的相同X和相同Y的点【LC1779】

    You are given two integers, x and y, which represent your current location on a Cartesian grid: (x, y). You are also given an array points where each points[i] = [ai, bi] represents that a point exists at (ai, bi). A point is valid if it shares the same x-coordinate or the same y-coordinate as your location.

    Return the index (0-indexed) of the valid point with the smallest Manhattan distance from your current location. If there are multiple, return the valid point with the smallest index. If there are no valid points, return -1.

    The Manhattan distance between two points (x1, y1) and (x2, y2) is abs(x1 - x2) + abs(y1 - y2).

    就是很奇怪 csdn发布文章总是要用手机的热点 校园网就进不来

    • 思路:遍历points数组,当point的横坐标与x相等或者纵坐标与y相等时,计算其与给定点的曼哈顿距离,返回距离最小的point的index即可

    • 实现

      class Solution {
          public int nearestValidPoint(int x, int y, int[][] points) {
              int minIndex = -1;
              int minDis = Integer.MAX_VALUE;
              for (int i = 0; i < points.length; i++){
                  if (points[i][0] == x || points[i][1] == y){
                      int dis = Math.abs(x - points[i][0]) + Math.abs(y - points[i][1]);
                      if (dis < minDis){
                          minIndex = i;
                          minDis = dis;
                      }
                  }
              }
              return minIndex;
      
          }
      }
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14
      • 15
      • 16
      • 17
      • 复杂度

        • 时间复杂度: O ( l o g n ) O(log n) O(logn)
        • 空间复杂度: O ( 1 ) O(1) O(1)
  • 相关阅读:
    java中的IO流之序列化与反序列化(对象数据和文件的读写交互)
    Vue组件自定义事件父子
    【0基础百日刷题】洛谷刷题知识拾遗
    SpringSecurity学习 - 认证和授权
    事务管理,事务的概念(原子性、一致性、隔离性和持久性(ACID特性))、事务的控制(BEGIN、COMMIT和ROLLBACK)
    代码随想录 单调栈part3
    【MySQL】MySQL的IFNULL()、ISNULL()、NULLIF()函数用法说明
    JAR 文件规范详解
    [].slice.call(arguments)
    Java进阶核心之InputStream流
  • 原文地址:https://blog.csdn.net/Tikitian/article/details/128127842
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号