news 2025/12/25 11:53:49

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进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/22 13:49:36

Free-NTFS-for-Mac完全指南:苹果电脑免费读写NTFS磁盘终极方案

Free-NTFS-for-Mac完全指南&#xff1a;苹果电脑免费读写NTFS磁盘终极方案 【免费下载链接】Free-NTFS-for-Mac Nigate&#xff0c;一款支持苹果芯片的Free NTFS for Mac小工具软件。NTFS R/W for macOS. Support Intel/Apple Silicon now. 项目地址: https://gitcode.com/gh…

作者头像 李华
网站建设 2025/12/23 2:32:55

MarkText主题定制全攻略:从入门到精通的5个核心技巧

MarkText主题定制全攻略&#xff1a;从入门到精通的5个核心技巧 【免费下载链接】marktext &#x1f4dd;A simple and elegant markdown editor, available for Linux, macOS and Windows. 项目地址: https://gitcode.com/gh_mirrors/ma/marktext 想要打造完全个性化的…

作者头像 李华
网站建设 2025/12/24 5:18:11

全面了解 Cookies、Session 和 Token

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家&#xff0c;历代文学网&#xff08;PC端可以访问&#xff1a;https://literature.sinhy.com/#/literature?__c1000&#xff0c;移动端可微信小程序搜索“历代文学”&#xff09;总架构师&#xff0c;15年工作经验&#xff0c;…

作者头像 李华
网站建设 2025/12/23 20:52:47

Calibre-Douban插件:一键获取豆瓣图书元数据的终极解决方案

还在为手动整理电子书信息而烦恼吗&#xff1f;Calibre-Douban插件就是你的电子书元数据管理神器&#xff01;这款基于网络爬虫技术的Calibre插件&#xff0c;能够智能抓取豆瓣图书网站的完整书籍信息&#xff0c;让电子书库瞬间变得井井有条。&#x1f4da; 【免费下载链接】c…

作者头像 李华
网站建设 2025/12/23 15:28:35

C#三大核心实战:字典、文件操作与委托全面解析

一、字典&#xff08;Dictionary&#xff09; 1. 核心特性 键值对集合&#xff1a;Dictionary<TKey, TValue>&#xff0c;键必须唯一&#xff0c;值可重复 快速查找&#xff1a;基于哈希表实现&#xff0c;键的查找接近O(1) 非线程安全&#xff1a;多线程需使用Concur…

作者头像 李华
网站建设 2025/12/23 21:56:23

Mac用户的NTFS救星:免费实现完美读写全攻略

Mac用户的NTFS救星&#xff1a;免费实现完美读写全攻略 【免费下载链接】Free-NTFS-for-Mac Nigate&#xff0c;一款支持苹果芯片的Free NTFS for Mac小工具软件。NTFS R/W for macOS. Support Intel/Apple Silicon now. 项目地址: https://gitcode.com/gh_mirrors/fr/Free-N…

作者头像 李华