文章目录

  • 1. 题目
  • 2. 解题

1. 题目

给你两个 非递增 的整数数组 nums1​​​​​​ 和 nums2​​​​​​ ,数组下标均 从 0 开始 计数。

下标对 (i, j)0 <= i < nums1.length0 <= j < nums2.length 。如果该下标对同时满足 i <= j 且 nums1[i] <= nums2[j] ,则称之为 有效 下标对,该下标对的 距离 为 j - i​​ 。​​

返回所有 有效 下标对 (i, j) 中的 最大距离 。如果不存在有效下标对,返回 0 。

一个数组 arr ,如果每个 1 <= i < arr.length 均有 arr[i-1] >= arr[i] 成立,那么该数组是一个 非递增 数组。

示例 1:
输入:nums1 = [55,30,5,4,2], nums2 = [100,20,10,10,5]
输出:2
解释:有效下标对是 (0,0), (2,2), (2,3), (2,4), (3,3), (3,4) 和 (4,4) 。
最大距离是 2 ,对应下标对 (2,4) 。示例 2:
输入:nums1 = [2,2,2], nums2 = [10,10,1]
输出:1
解释:有效下标对是 (0,0), (0,1) 和 (1,1) 。
最大距离是 1 ,对应下标对 (0,1) 。示例 3:
输入:nums1 = [30,29,19,5], nums2 = [25,25,25,25,25]
输出:2
解释:有效下标对是 (2,2), (2,3), (2,4), (3,3) 和 (3,4) 。
最大距离是 2 ,对应下标对 (2,4) 。示例 4:
输入:nums1 = [5,4], nums2 = [3,2]
输出:0
解释:不存在有效下标对,所以返回 0 。提示:
1 <= nums1.length <= 10^5
1 <= nums2.length <= 10^5
1 <= nums1[i], nums2[j] <= 10^5
nums1 和 nums2 都是 非递增 数组

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/maximum-distance-between-a-pair-of-values
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • 对数组1的每个元素在 逆序的数组2中二分查找,时间复杂度 O(n1log⁡n2)O(n1 \log n2)O(n1logn2)
class Solution {public:int maxDistance(vector<int>& nums1, vector<int>& nums2) {int n1 = nums1.size(), n2 = nums2.size(), i = 0, j = 0, ans = 0;reverse(nums2.begin(), nums2.end());//升序for(int i = 0; i < n1; ++i){auto it = lower_bound(nums2.begin(), nums2.end(), nums1[i]);//找到大于等于 nums1 i 的第一个数,其 序号 是原始顺序下最大的if(it != nums2.end()){int j = it - nums2.begin();//距离if(n2-1-j > i)//原始序号 > ians = max(ans, n2-1-j-i);}}return ans;}
};
  • 双指针解法,参考官网,时间复杂度 O(n1+n2)O(n1+n2)O(n1+n2)
class Solution {public:int maxDistance(vector<int>& nums1, vector<int>& nums2) {int n1 = nums1.size(), n2 = nums2.size(), i = 0, j = 0, ans = 0;for( ; j < n2 && i < n1; ++j){while(i < n1 && nums1[i] > nums2[j])//不满足要求,i++;//减小 nums iif(j > i && i < n1)ans = max(ans, j-i);}return ans;}
};

228 ms 96.1 MB C++


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!

LeetCode 1855. 下标对中的最大距离(双指针)相关推荐

  1. LeetCode 624. 数组列表中的最大距离

    文章目录 1. 题目 2. 解题 2.1 暴力超时 2.2 优化 1. 题目 给定 m 个数组,每个数组都已经按照升序排好序了. 现在你需要从两个不同的数组中选择两个整数(每个数组选一个)并且计算它们 ...

  2. 【Leetcode -1721.交换链表中的节点 -2058.找出临界点之间的最小和最大距离】

    Leetcode Leetcode -1721.交换链表中的节点 Leetcode -2058.找出临界点之间的最小和最大距离 Leetcode -1721.交换链表中的节点 题目:给你链表的头节点 ...

  3. C#版(击败97.76%的提交) - Leetcode 557. 反转字符串中的单词 III - 题解

    版权声明: 本文为博主Bravo Yeung(知乎UserName同名)的原创文章,欲转载请先私信获博主允许,转载时请附上网址 http://blog.csdn.net/lzuacm. Leetcod ...

  4. leetcode周赛5465. 子树中标签相同的节点数

    leetcode周赛5465. 子树中标签相同的节点数 给你一棵树(即,一个连通的无环无向图),这棵树由编号从 0 到 n - 1 的 n 个节点组成,且恰好有 n - 1 条 edges .树的根节 ...

  5. Leetcode 557 反转字符串中的单词

    Leetcode 557 反转字符串中的单词 题目描述: 给定一个字符串 s ,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序. 示例1: 输入:s = "Let's ...

  6. LeetCode 1617. 统计子树中城市之间最大距离(枚举所有可能+图的最大直径)

    文章目录 1. 题目 2. 解题 1. 题目 给你 n 个城市,编号为从 1 到 n .同时给你一个大小为 n-1 的数组 edges ,其中 edges[i] = [ui, vi] 表示城市 ui ...

  7. LeetCode 1802. 有界数组中指定下标处的最大值(思维题)

    文章目录 1. 题目 2. 解题 1. 题目 给你三个正整数 n.index 和 maxSum . 你需要构造一个同时满足下述所有条件的数组 nums(下标 从 0 开始 计数): nums.leng ...

  8. LeetCode 438. 找到字符串中所有字母异位词(双指针+滑动窗口)

    题目描述 给定一个字符串 s 和一个非空字符串 p,找到 s 中所有是 p 的字母异位词的子串,返回这些子串的起始索引. 字符串只包含小写英文字母,并且字符串 s 和 p 的长度都不超过 20100. ...

  9. LeetCode 2149. 按符号重排数组(双指针)

    文章目录 1. 题目 2. 解题 1. 题目 给你一个下标从 0 开始的整数数组 nums ,数组长度为 偶数 ,由数目相等的正整数和负整数组成. 你需要 重排 nums 中的元素,使修改后的数组满足 ...

最新文章

  1. Threejs加载模型问题汇总
  2. NYOJ 745 蚂蚁的难题(二)
  3. 使用Dottrace跟踪代码执行时间
  4. Windows7下注册OCX的注意事项
  5. php 去掉实体,用PHP删除除5个预定义HTML实体之外的所有实体的最佳方法-用于XHTML5输出...
  6. 七、制作主题(二) Anatomy of a theme
  7. 计算面平均边_家装门窗订单常用的门窗尺寸测量和计算方法
  8. 21款网页版html5小游戏源码
  9. RFID技术中各频段电子标签的特点及其应用领域
  10. poi填充word,动态生成表格+LibreOffice转成pdf
  11. 计算机辅助审计在外汇,外汇管理领域计算机辅助审计
  12. 【抽象代数】半群、子群、商群
  13. dijistra算法
  14. 使用 crictl 对 Kubernetes 节点进行调试
  15. 怎么查ip地址 多种方法教学
  16. 如何使用加速度计实现倾斜角度计算
  17. 九爷带你了解 nginx优化
  18. 柏西机器人_《勿忘我》孔木猴 ^第9章^ 最新更新:2020-07-25 08:35:09 晋江文学城_手机版...
  19. 银行大数据应用案例(研讨会整理)
  20. nodejs爬虫与python爬虫_Python,Node.js 哪个比较适合写爬虫?

热门文章

  1. 清华大学《操作系统》(十二):临界区与锁
  2. react接收后端文件_React获取Java后台文件流并下载Excel文件流程解析
  3. 托福试卷真题_干货解答考生疑惑,自考真题考过了还会在出吗?
  4. html 圆环实现多种颜色,SVG实现多彩圆环倒计时效果的示例代码
  5. Visual C++中 #include stdafx.h 头文件的用法
  6. html5调用手机摄像头和相册,h5 调用手机摄像头/相册
  7. python 编程模型
  8. Sublime text3 代码格式化插件vue
  9. Python 如何调用 Java
  10. Python调用C的方法