当前位置: 首页 > news >正文

L48---1637. 两点之间不包含任何点的最宽垂直区域(排序)---Java版

1.题目描述

在这里插入图片描述
在这里插入图片描述

2.思路

(1)返回两点之间内部不包含任何点的 最宽垂直区域 的宽度。
我的理解是相邻两个点,按照等差数列那样,后一个数减去相邻的前一个数,才能保证两数之间不含其他数字。
(2)所以,我们先对点坐标的横坐标进行排序。
(3)如果按横坐标比较,(a, b) -> a[0] - b[0] 是一个函数式接口 Comparator 的实现,它定义了一个比较规则,用于比较两个元素的大小。
a 和 b 分别表示数组中的两个元素而 a[0] - b[0] 表示按照数组元素的第一个值(也就是 x 坐标)进行升序排序。
(4)如果按纵坐标进行排序,在这个比较器中,(a, b) -> a[1] - b[1] 表示按照数组元素的第二个值(也就是 y 坐标)进行升序排序。
(4)第一个索引值 i 表示数组 points 中的第 i 个元素,而第二个索引值 0 表示这个元素中的第一个值(也就是 x 坐标)。所以 points[i][0] 表示数组 points 中第 i 个元素的 x 坐标值。
就是把坐标看出二维矩阵;

3.代码实现

class Solution {
    public int maxWidthOfVerticalArea(int[][] points) {

        Arrays.sort(points,(a,b)->a[0]-b[0]);//任意两个元素的横坐标的差值进行排序

        int maxAreas=0;//如果所有的点都垂直x轴,则最大值为0

        for(int i=1;i<=points.length-1;i++)
        {
            int maxdis=points[i][0]-points[i-1][0];
            maxAreas=Math.max(maxdis,maxAreas);
        }

        return maxAreas;



    }
}

相关文章:

  • 申请医疗设备注册变更时,需要补充考虑网络安全的情况有哪些?
  • R语言数据探索和分析23-公共物品问卷分析
  • 2024年6月9日 (周日) 叶子游戏新闻
  • Django API开发实战:前后端分离、Restful风格与DRF序列化器详解
  • Android Qt开发环境部署
  • 设计模式-中介者(调停者)模式(行为型)
  • C++青少年简明教程:字符类型、字符数组和字符串
  • Scala 练习一 将Mysql表数据导入HBase
  • Django中间件
  • 产品NPDP+项目PMP助你成长
  • Day17—JavaScript与Ajax请求分析
  • 以sqlilabs靶场为例,讲解SQL注入攻击原理【42-53关】
  • [HGAME 2023 week4]shellcode
  • 在CSS中,可以使用`float`属性来设置元素浮动
  • Java--命令行传参
  • Elasticsearch 认证模拟题 - 15
  • Web前端不挂科:深入探索与实战指南
  • Python课设-学生信息管理系统
  • Rust-03-数据类型
  • 医疗器械网络安全风险管理的基本步骤
  • 青岛鞋企双星名人集团家族内斗:创始人发公开信指控子孙夺权
  • 中俄合拍电影《红丝绸》将于今年9月在中国上映
  • 上海畅通“外转内”,外贸优品成“香饽饽”
  • “五一”前两日湖北20多家景区实施限流
  • 上海环球马术冠军赛开赛,一场体育与假日消费联动的狂欢
  • 美法官裁定特朗普援引战时法律驱逐黑帮违法,系首次永久性驳回