首页 > 其他分享 >leetcode-624.数组列表中的最大距离

leetcode-624.数组列表中的最大距离

时间:2024-06-02 19:59:33浏览次数:26  
标签:index 624 max min 列表 vec 数组 排序 leetcode

数组列表中的最大距离

给定 m 个数组,每个数组都已经按照升序排好序了。现在你需要从两个不同的数组中选择两个整数(每个数组选一个)并且计算它们的距离。两个整数 a 和 b 之间的距离定义为它们差的绝对值 |a-b| 。你的任务就是去找到最大距离

目标

题意中的绝对值 |a-b|等价于选取两个数组的最大、最小值相减;由于每个数组已经排序,进一步等价于\(\max(vec[i][n-1] - vec[j][0], vec[j][m-1] - vec[i][0])\)。

直观想法

找 \(\min(vec[i][0])\)和\(\max(vec[i][n-1])\),但是还需要保障这两个数不在同一个数组中,由此产生思路:

  1. 依照 vec[i][0] 的值从小到大进行排序(不直接排序原数组,而是新申请 index 数组进行排序),得到 \(index_1\)
  2. 依照 vec[i][n-1] 的值从大到小进行排序 (不直接排序原数组,而是新申请 index 数组进行排序),得到 \(index_2\)
  3. 比较两个 index 数组的第一个值是否相等,不相等则说明不是同一个数组,可直接计算得出结果;相等则还需要拿出两个index数组的第二个值进行计算比较得出结果

最优解思路

1. 仅仅两个数组a, b

很好解决——选择 \(a_{max} - b_{min}\) 和 \(b_{max} - a_{min}\) 的最大值

2. 三个数组 a, b, c

通过步骤1,可以得到一个潜在结果 ans;对于 c 的加入,选择 $ \max(a_{max}, b_{max}) - c_{min}$ 和 $c_{max} - \min(a_{min}, b_{min}) $ 的最大值

3. 进一步范化

已知 m-1 个数组的答案,而且知道真个数组的最大、最小值,先加入一个新的数组,计算得到答案。由此可以得到时间复杂度为\(O(n)\),空间复杂度为\(O(1)\)的方法

标签:index,624,max,min,列表,vec,数组,排序,leetcode
From: https://www.cnblogs.com/wyzwsy/p/18227472

相关文章

  • Leetcode 3161. 物块放置查询
    https://leetcode.cn/problems/block-placement-queries/description/有一条无限长的数轴,原点在0处,沿着x轴正方向无限延伸。给你一个二维数组queries,它包含两种操作:操作类型1:queries[i]=[1,x]。在距离原点x处建一个障碍物。数据保证当操作执行的时候,位置x处......
  • 【leetcode】——第 400 场周赛,2题选手签个到
    第一题:100307.候诊室中的最少椅子数给你一个字符串 s,模拟每秒钟的事件 i:如果 s[i]=='E',表示有一位顾客进入候诊室并占用一把椅子。如果 s[i]=='L',表示有一位顾客离开候诊室,从而释放一把椅子。返回保证每位进入候诊室的顾客都能有椅子坐的 最少 椅子数,假设候诊室......
  • leetCode.89. 格雷编码
    leetCode.89.格雷编码题目思路代码classSolution{public:vector<int>grayCode(intn){vector<int>res(1,0);//n=0时,之后一位0while(n--){//想要实现对象超下来,就从末尾开始,让vector里面加元素for(......
  • leetCode.90. 子集 II
    leetCode.90.子集II题目思路代码classSolution{public:vector<vector<int>>res;vector<int>path;vector<vector<int>>subsetsWithDup(vector<int>&nums){//先排序,让有相同元素的都放到一起sort(nums.be......
  • [补题记录]LeetCode 6.Z字形变换
    传送门:Z字形变换转自:Z字形变换Thought/思路关键点在于,最后的答案是一行行连接起来的。这样我们就会发现,这个Z字,实际上会让行数不断加1,然后又不断减1。每次按顺序选择S中的一个字符即可。Code/代码classSolution{public:stringconvert(strings,int......
  • [leetcode 第 400 场周赛]题解
    第一题:classSolution{publicintminimumChairs(Strings){intx=0;intans=0;for(inti=0;i<s.length();i++){if(s.charAt(i)=='E'){x--;if(x<0){ans++;x=0;......
  • 什么!你还在学列表和元组?!这一篇文章就够了!之Python基础篇-列表与元组
    列表定义列表的格式:列表名=[元素1,元素2,元素3,......]空列表的定义:my_list=[](常用)  或  my_list=list()列表中的元素不需要具有相同的类型。#定义列表list1,且列表中的元素不具有相同的类型>>>list1=['xiaoming','m',201,54,'13458714']>>>type(list......
  • 【LeetCode:575. 分糖果+ 哈希表】
    ......
  • LeetCode 1652. 拆炸弹
    1652.拆炸弹你有一个炸弹需要拆除,时间紧迫!你的情报员会给你一个长度为 n 的 循环 数组 code 以及一个密钥 k 。为了获得正确的密码,你需要替换掉每一个数字。所有数字会 同时 被替换。如果 k>0 ,将第 i 个数字用 接下来 k 个数字之和替换。如果 k<0 ,......
  • Q3 LeetCode34 在排序数组中找起始位置
    提交错误:数组访问越界1.验证数组越界的语句要放在执行语句的前面,要不然前面报错无法进行到后面部分2.本题使用两次二分查找,左边界找到后,将rigiht指针设置成mid-1,继续查找更左的边界,右边界同理将left设置成mid+13.newint[]{1,1}  新数组创建方式 1classSolution{......