【Leetcode 每日一题】624. 数组列表中的最大距离

问题背景

给定 m m m 个数组,每个数组都已经按照升序排好序了。

现在你需要从两个不同的数组中选择两个整数(每个数组选一个)并且计算它们的距离。两个整数 a a a 和 b b b 之间的距离定义为它们差的绝对值 ∣ a − b ∣ |a-b| ∣a−b∣。

返回最大距离。

数据约束

  • m = a r r a y s . l e n g t h m = arrays.length m=arrays.length
  • 2 ≤ m ≤ 1 0 5 2 \le m \le 10 ^ 5 2≤m≤105
  • 1 ≤ a r r a y s i . l e n g t h ≤ 500 1 \le arraysi.length \le 500 1≤arraysi.length≤500
  • − 1 0 4 ≤ a r r a y s i j ≤ 1 0 4 -10 ^ 4 \le arraysij \le 10 ^ 4 −104≤arraysij≤104
  • a r r a y s i arraysi arraysi升序 排序。
  • 所有数组中最多有 1 0 5 10 ^ 5 105 个整数。

解题过程

自己没轻易地实现出一组只有一个数的效果,还没意识到减法可能溢出,鉴定为题做少了。

具体实现

java 复制代码
class Solution {
    public int maxDistance(List<List<Integer>> arrays) {
        int min = Integer.MAX_VALUE >> 1;
        int max = Integer.MIN_VALUE >> 1;
        int res = 0;
        for (List<Integer> array : arrays) {
            int cur1 = array.get(0);
            int cur2 = array.get(array.size() - 1);
            res = Math.max(res, Math.max(cur2 - min, max - cur1));
            min = Math.min(min, cur1);
            max = Math.max(max, cur2);
        }
        return res;
    }
}
相关推荐
开源Z1 小时前
LeetCode 42 · 接雨水:从暴力到双指针的三步优化
算法·leetcode
旖-旎1 小时前
《LeetCode 695 岛屿的最大面积 FloodFill DFS 解法》
c++·算法·力扣·深度优先遍历·floodfill
影视飓风TIM1 小时前
数据结构 | 链表超全笔记(单链表+双链表+高频算法题)
数据结构·笔记·链表
syagain_zsx1 小时前
STL 之 vector 讲练结合
c++·算法
牛油果子哥q2 小时前
STL set与map底层精讲,红黑树适配原理、有序去重特性、迭代器遍历、API实战与面试核心考点全解
开发语言·数据结构·c++·面试
MartinYeung53 小时前
[论文学习]DP2Unlearning:高效且具保证的大型语言模型遗忘框架(基于差分隐私的 LLM Unlearning 方法)
学习·算法·语言模型
Tian_Hang3 小时前
C++原型模式(Protype)
开发语言·c++·算法
bIo7lyA8v3 小时前
算法复杂度的渐进分析与实际运行时间的差异的技术8
算法
一切皆是因缘际会4 小时前
LLM轻量化联邦微调机理
数据结构·人工智能·数学建模·ai