news 2026/6/19 11:53:41

D.二分查找-进阶——1385. 两个数组间的距离值

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
D.二分查找-进阶——1385. 两个数组间的距离值

题目链接:1385. 两个数组间的距离值(简单)

算法原理:

大致思路与👇相同,这题还稍微简单些

D.二分查找-进阶——2300. 咒语和药水的成功对数

解法:二分查找

对于arr1中的每一个元素x,不符合题意的区间是[x-d,x+d],所以可以对arr2排序进行二分来找最左端点x-d或者最右端点x+d

思路一:找最左端点模型解法

7ms击败38.02%

时间复杂度O(Nlogn)

找最左端点x-d,如果没有x-d那么最终left的位置是x-d右侧的

①如果该数小于x-d,说明此时left在最后一个位置,数组arr2中所有元素均小于x-d,自然符合题意,ret++

②如果该数大于x+d,说明此时left在第一个位置,数组arr2中所有元素均大于x+d,自然符合题意,ret++

思路二:找最右端点模型解法

7ms击败38.02%

时间复杂度O(Nlogn)

找最右端点x+d,如果没有x+d那么最终left的位置是x+d左侧的

其余均与思路一相同

Java代码:

class Solution { public int findTheDistanceValue(int[] arr1, int[] arr2, int d) { int n=arr2.length,ret=0; Arrays.sort(arr2); for(int x:arr1){ //找最左端点模型解法 int t=x-d; int left=0,right=n-1; while(left<right){ int mid=left+(right-left)/2; if(arr2[mid]<x-d) left=mid+1; else right=mid; } //arr2[left]<x-d:说明所有的数都比x-d小,全符合条件 //arr2[left]>x+d:说明所有的数都比x-d大,全符合条件 if(arr2[left]<x-d||arr2[left]>x+d) ret++; } return ret; } }
class Solution { public int findTheDistanceValue(int[] arr1, int[] arr2, int d) { int n=arr2.length,ret=0; Arrays.sort(arr2); for(int x:arr1){ //找最右端点模型解法 int t=x-d; int left=0,right=n-1; while(left<right){ int mid=left+(right-left+1)/2; if(arr2[mid]>x+d) right=mid-1; else left=mid; } //arr2[left]<x-d:说明所有的数都比x-d小,全符合条件 //arr2[left]>x+d:说明所有的数都比x-d大,全符合条件 if(arr2[left]<x-d||arr2[left]>x+d) ret++; } return ret; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/19 10:26:36

资源下载神器Res-Downloader完全指南:5分钟学会全网资源轻松获取

想要快速下载微信视频号、抖音快手无水印视频、酷狗音乐等网络资源吗&#xff1f;Res-Downloader资源下载器为你提供了一站式解决方案&#xff01;这款基于Go语言开发的跨平台工具&#xff0c;集成了网络资源嗅探与高速下载功能&#xff0c;让资源获取变得前所未有的简单高效。…

作者头像 李华
网站建设 2026/6/10 17:07:43

如何快速下载B站视频:新手也能掌握的完整指南

如何快速下载B站视频&#xff1a;新手也能掌握的完整指南 【免费下载链接】bilibili-downloader B站视频下载&#xff0c;支持下载大会员清晰度4K&#xff0c;持续更新中 项目地址: https://gitcode.com/gh_mirrors/bil/bilibili-downloader 你是否曾经遇到过这样的情况…

作者头像 李华
网站建设 2026/6/12 21:34:24

GPT-SoVITS:零基础打造专属AI语音的终极指南

GPT-SoVITS&#xff1a;零基础打造专属AI语音的终极指南 【免费下载链接】GPT-SoVITS 项目地址: https://gitcode.com/GitHub_Trending/gp/GPT-SoVITS 想要拥有属于自己的AI语音助手吗&#xff1f;GPT-SoVITS让语音合成变得前所未有的简单&#xff01;无论你是想制作个…

作者头像 李华
网站建设 2026/6/17 4:09:35

AutoGPT水质检测报告生成器

AutoGPT水质检测报告生成器 在环境监测一线&#xff0c;技术人员常常面临这样的困境&#xff1a;采集了数十个采样点的水质数据&#xff0c;却要在接下来的几个小时里手动比对国家标准、逐项判断合规性、整理成格式统一的报告。稍有疏忽&#xff0c;就可能漏掉一个超标指标&…

作者头像 李华