IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> LeetCode 1855. 下标对中的最大距离 -> 正文阅读

[数据结构与算法]LeetCode 1855. 下标对中的最大距离

题目链接:

力扣icon-default.png?t=M4ADhttps://leetcode.cn/problems/maximum-distance-between-a-pair-of-values/

【方法一 二分查找】枚举nums2中的元素,在nums1中查找<=nums2[i]的最小下标元素。

class Solution {
    
    public int binarySearch(int[] nums, int target){
        int left = 0, right = nums.length - 1;
        while(left <= right){
            int mid = (left + right) >>> 1;
            if(nums[mid] <= target){
                right = mid - 1;
            }else{
                left = mid + 1;
            }
        }
        return left;
    }

    public int maxDistance(int[] nums1, int[] nums2) {
        int n = nums2.length, m = nums1.length;
        int ans = 0;
        for(int i = 0; i < n; i++){
            int idx = binarySearch(nums1, nums2[i]);
            if(idx >=0 && idx < m && nums1[idx] <= nums2[i]) ans = Math.max(ans, i - idx);
        }
        return ans;
    }
}

【改进】 缩短一下查找的距离,只找i左侧的

class Solution {

    int[] nums;
    int m;
    
    public int binarySearch(int right, int target){
        int left = 0;
        right = Math.min(right, m - 1);
        while(left <= right){
            int mid = (left + right) >>> 1;
            if(nums[mid] <= target){
                right = mid - 1;
            }else{
                left = mid + 1;
            }
        }
        return left;
    }

    public int maxDistance(int[] nums1, int[] nums2) {
        nums = nums1; m = nums1.length;
        int n = nums2.length;
        int ans = 0;
        for(int i = 0; i < n; i++){
            int idx = binarySearch(i - 1, nums2[i]);
            if(idx >=0 && idx < m && nums1[idx] <= nums2[i]) ans = Math.max(ans, i - idx);
        }
        return ans;
    }
}

【方法二 双指针】要求nums1[i]<=nums2[j],我们就去找第一个nums2[j]<nums1[i]即可

class Solution {
    public int maxDistance(int[] nums1, int[] nums2) {
        int i = 0, j = 0, m = nums1.length, n = nums2.length;
        int ans = 0;
        for(i = 0; i < m; i++){
            while(j < n && nums2[j] >= nums1[i]) j++;
            ans = Math.max(ans, j - i - 1);
            if(j == n) break;
        }
        return ans;
    }
}

?

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-05-14 10:09:04  更:2022-05-14 10:09:34 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 4:38:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码