3102.力扣每日一题7/9 Java(TreeMap)

  • 博客主页:音符犹如代码
  • 系列专栏:算法练习
  • 关注博主,后期持续更新系列文章
  • 如果有错误感谢请大家批评指出,及时修改
  • 感谢大家点赞👍收藏⭐评论✍

 

 

目录

TreeMap详解

解题思路

解题方法

时间复杂度

空间复杂度

Code 


TreeMap 详解

TreeMap 是 Java 中的一种数据结构,属于 Map 接口的实现类之一。

主要特点:

  1. 有序性TreeMap 中的键是按照自然顺序(对于实现了 Comparable 接口的键)或者自定义的比较器所定义的顺序进行存储和排序的。这使得遍历 TreeMap 时能按照特定的顺序获取键值对。
  2. 底层结构:其底层基于红黑树实现,红黑树是一种自平衡的二叉搜索树,保证了插入、删除和查找操作的平均时间复杂度为 ,其中 n 是键的数量。
  3. 键的要求:键必须是可比较的。如果键的类型没有实现 Comparable 接口,那么在创建 TreeMap 时必须提供一个自定义的比较器。

常见操作和方法:

  1. put(K key, V value):向 TreeMap 中添加键值对。
  2. get(Object key):根据给定的键获取对应的值。
  3. containsKey(Object key):检查 TreeMap 是否包含指定的键。
  4. firstKey():返回 TreeMap 中的第一个键。
  5. lastKey():返回 TreeMap 中的最后一个键。
  6. lowerKey(K key):返回小于指定键的最大键。
  7. higherKey(K key):返回大于指定键的最小键。

应用场景:

  1. 当需要按照键的特定顺序进行存储和访问时,例如需要对键进行有序遍历。
  2. 当需要快速查找特定范围内的键值对时,利用其有序性和相关的方法(如 subMap )。

总的来说,TreeMap 提供了有序存储和操作键值对的功能,适用于对数据顺序有要求的场景。但在某些情况下,如果不关心顺序,使用 HashMap 可能在性能上更有优势,因为其操作的平均时间复杂度更低。

解题思路

首先,使用两个 TreeMap(xs 和 ys)分别对所有点的 x + y 和 y - x 的值进行计数。
然后通过遍历每个点,模拟移除该点后更新 TreeMap 中的计数。
计算更新后的 TreeMap 中键的最大值和最小值的差值(dx 和 dy),并与当前的最小最大距离 ans 进行比较和更新。

解题方法

  1. 初始化阶段:

    • 创建两个 TreeMap 对象 xs 和 ys
    • 遍历输入的点数组 points ,对于每个点 p ,计算 x = p[0] + p[1] 和 y = p[1] - p[0] 。
    • 使用 merge 方法将 x 和 y 及其出现次数累加到对应的 TreeMap 中。如果 x 或 y 已经存在,就将其计数加 1;如果不存在,就初始化为 1。
  2. 核心处理阶段:

    • 初始化最小最大距离 ans 为 Integer.MAX_VALUE 。
    • 再次遍历点数组 points 。
    • 对于每个点,重新计算其对应的 x 和 y 。
    • 检查 xs 中 x 的计数:
      • 如果计数为 1 ,则从 xs 中移除 x 。
      • 如果计数大于 1 ,则将其计数减 1 。
    • 对 ys 中 y 进行类似的处理。
    • 计算 xs 中最大键值和最小键值的差值 dx ,以及 ys 中最大键值和最小键值的差值 dy 。
    • 取 dx 和 dy 中的最大值,与当前的 ans 比较并更新 ans 为较小值。
    • 最后,如果 x 不在 xs 中,就将其添加并初始计数为 1 ;否则将其计数加 1 。对 y 在 ys 中的处理也是类似的。
  3. 最终返回 ans ,即恰好移除一个点后任意两点之间最大距离可能的最小值。

时间复杂度

  • 初始化 TreeMap 的时间复杂度为O(n) ,其中 n 是点的数量。
  • 对每个点进行处理的时间复杂度为O(n log n) ,因为涉及到对 TreeMap 的操作。
  • 总的时间复杂度为 O(n²log n)

空间复杂度

使用了两个 TreeMap 来存储点的相关信息,空间复杂度为 O(n)

Code

import java.util.TreeMap;class Solution {public int minimumDistance(int[][] points) {TreeMap<Integer, Integer> xs = new TreeMap<>();TreeMap<Integer, Integer> ys = new TreeMap<>();for (int[] p : points) {int x = p[0] + p[1];int y = p[1] - p[0];xs.merge(x, 1, Integer::sum);ys.merge(y, 1, Integer::sum);}int ans = Integer.MAX_VALUE;for (int[] p : points) {int x = p[0] + p[1];int y = p[1] - p[0];if (xs.get(x) == 1) {xs.remove(x);} else {xs.merge(x, -1, Integer::sum);}if (ys.get(y) == 1) {ys.remove(y);} else {ys.merge(y, -1, Integer::sum);}int dx = xs.lastKey() - xs.firstKey();int dy = ys.lastKey() - ys.firstKey();ans = Math.min(ans, Math.max(dx, dy));if (!xs.containsKey(x)) {xs.put(x, 1);} else {xs.merge(x, 1, Integer::sum);}if (!ys.containsKey(y)) {ys.put(y, 1);} else {ys.merge(y, 1, Integer::sum);}}return ans;}
}

穷不失义,达不离道。——孔丘《论语》

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/869838.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Python】 已解决:ModuleNotFoundError: No module named…

文章目录 一、分析问题背景二、可能出错的原因三、错误代码示例四、正确代码示例五、注意事项 已解决&#xff1a;ModuleNotFoundError: No module named… 一、分析问题背景 在使用Python进行开发时&#xff0c;有时会遇到“ModuleNotFoundError: No module named…”这样的…

创新设计策略:提升大屏幕可视化设计效果的关键方法

随着科技的不断发展和数据量的快速增长&#xff0c;数据可视化大屏在各个行业中的应用越来越广泛&#xff0c;可以帮助人们更好地理解和分析数据&#xff0c;可视化大屏设计也因此成了众多企业的需求。但很多设计师对可视化大屏设计并不了解&#xff0c;也不知道如何制作可视化…

谁说forEach不支持异步代码,只是你拿不到异步结果而已

在前面探讨 forEach 中异步请求后端接口时&#xff0c;很多人都知道 forEach 中 async/await 实际是无效的&#xff0c;很多文章也说&#xff1a;forEach 不支持异步&#xff0c;forEach 只能同步运行代码&#xff0c;forEach 会忽略 await 直接进行下一次循环… 当时我的理解…

[GICv3] 1.引言Introduction

基本概念 通用中断控制器 (GIC) 从外设获取中断&#xff0c;确定它们的优先级&#xff0c;然后将它们传送到适当的处理器内核。 下图了为一个 GIC 从 n 个不同的外设获取中断&#xff0c;并将它们分配给两个不同的处理器。 ​​ GCI(Generic Interrupt Controller)&#xff0c…

AI Agent 的发展现状、行业结构与趋势分析

Agent 来自一种哲学概念&#xff0c;是个很古老的哲学术语&#xff0c;从哲学意义上讲&#xff0c;“代理”的概念涉及实体的自主性&#xff0c;具有行使意志、做出选择和采取行动的能力&#xff0c;而不是被动地对外部刺激做出反应。后来人们将这一概念引入计算机科学领域&…

ApiFox或postman怎么用params类型传输json或集合+json的String类型

你是否碰见过这样的接口? post请求然后传输的参数都要和查询时一样以param形式传参数,那String什么的都好说,传就直接进后台了,那json呢,集合呢,是不是直接给你返400呢. 1.传json如何处理 那我们看看怎么实现,如果你要传json数据,那需要将特殊字符转义,也叫url转码,否则传不…

【HarmonyOS】关于官方推荐的组件级路由Navigation的心得体会

前言 最近因为之前的630版本有点忙&#xff0c;导致断更了几天&#xff0c;现在再补上。换换脑子。 目前内测系统的华为应用市场&#xff0c;各种顶级APP陆续都放出来beta版本了&#xff0c;大体上都完成了主流程的开发。欣欣向荣的气息。 学习思路 关于学习HarmonyOS的问题…

热点解读 | 小红书「县城生活」趋势前瞻

“县城婆罗门”、“月薪两万不如县城贵妇”、“北漂打工人回县城被穷笑”……继中产之后&#xff0c;县城成为又一个全网热议的焦点。 县城叙事重返舆论场&#xff0c;本期千瓜将进一步解构「县城」语境下的个体表现&#xff0c;帮助品牌沉淀用户心智&#xff0c;塑造新时代竞争…

​​​防御第一次作业

1、拓扑图及实验要求&#xff1a; 2、配置&#xff1a; 配置终端及服务器IP地址&#xff1a; Pc2&#xff1a; Client1&#xff1a; Pc4&#xff1a; Client2&#xff1a; PC1&#xff1a; Server1&#xff1a; Server2&#xff1a; 防火墙基础配置&#xff1a; [fw1]int g …

maven 依赖冲突

依赖冲突 1、对于 Maven 而言&#xff0c;同一个 groupId 同一个 artifactId 下&#xff0c;只能使用一个 version。 <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-math3 --><dependency><groupId>org.apache.commons</groupId&…

手搓前端day1

断断续续的学了些前端&#xff0c;今天开始写写代码&#xff0c;就当是记录一下自己前端的成长过程 效果&#xff1a; 写了点css&#xff0c;实现了简单的前端页面的跳转 文件目录 代码如下&#xff1a; styles.css body{margin: 0;padding: 0;}header{background-color: bl…

系统服务综合作业

首先配置自动挂载 服务器的/rhce 自动挂载在客服端的/nfs/rhce 首先在服务器进行配置 dnf install nfs-utils -y [rootlocalhost ~]# vim /etc/exports [rootlocalhost ~]# firewall-cmd --permanent --add-servicenfs success [rootlocalhost ~]# firewall-cmd --permanen…

常见的嵌入式软件体系结构

本文介绍常见的嵌入式软件体系结构。 在嵌入式开发过程中&#xff0c;尤其是MCU为主控的项目开发中&#xff0c;实时性是需要考虑的重要因素&#xff0c;本文介绍常见的2种嵌入式软件体系结构&#xff0c;并对其优缺点作简要分析&#xff0c;另外&#xff0c;还对它们的软件层…

食物链之带权并查集解法

直接看题&#xff1a;https://www.acwing.com/problem/content/description/242/ 下面就是代码的实现了&#xff0c;因为自己与自己肯定是同类我们初始化为0. 下面是AC代码&#xff1a; #include<bits/stdc.h> using namespace std; int n,k; int fk,x,y; int fa[10001…

【Python实战因果推断】29_倾向分9

目录 Outcome Is Easy to Model Generalized Propensity Score for Continuous Treatment Outcome Is Easy to Model 在下一个简单而又能说明问题的例子中&#xff0c;复杂性在于 而不是 。注意 中的非线性&#xff0c;而结果函数是简单的线性。在这里&#xff0c;真正的 A…

【操作系统】进程管理——调度算法(个人笔记)

学习日期&#xff1a;2024.7.4 内容摘要&#xff1a;各种调度算法的思想、规则、优缺点介绍 为什么要有调度算法&#xff1f; 调度算法就好比一群人在银行办理业务&#xff0c;准备办理业务的人就是进程/作业&#xff0c;银行窗口的工作人员就是CPU&#xff0c;进程往往是比C…

xcode配置swift使用自定义主题颜色或者使用RGB或者HEX颜色

要想在xcode中使用自定义颜色或者配置主题色&#xff0c;需要在Assets中配置&#xff0c;打开Assets文件&#xff0c;然后点击添加Color Set&#xff1a; 输入颜色的名称&#xff0c;然后选中这个颜色&#xff0c;会出现两个颜色&#xff1a; Any Appearance表示亮色模式下使用…

评估测试用例有效性 5个方面

评估测试用例的有效性是确保软件测试活动能够达到预期目标的关键步骤&#xff0c;有助于测试团队优化测试计划&#xff0c;提高测试效率&#xff0c;减少返工&#xff0c;节省成本。如果缺乏对测试用例的有效性评估&#xff0c;可能会导致测试用例无法覆盖关键功能点&#xff0…

SpringCloud代码实战

项目结构 实例实现功能:实现通过id查询用户的订单信息 OrderCommon&#xff1a;公共的一些模块类型&#xff0c;此处为一个user对象 Eureka-Service:配置Eureka的启动类&#xff0c;服务端 Order-Service:提供查询功能的服务端 Order-Client:查询的客户端 OrderCommon代码…

智汇园区:为园区企业注入前沿技术与人才活力

在日新月异的时代浪潮中&#xff0c;树莓集团深知人才是企业发展的核心驱动力&#xff0c;更是推动产业升级与创新的关键要素。因此&#xff0c;我们致力于构建全方位的人才引进与培养体系&#xff0c;为园区企业输送源源不断的前沿技术与人才支持。 【人才引进&#xff1a;汇聚…