JavaScript实现两个数组的交集


Posted in Javascript onMarch 25, 2022

两个数组的交集 I

给定两个数组 ​​nums1​​​ 和 ​​nums2​​ ,返回 它们的交集 。输出结果中的每个元素一定是 唯一 的。我们可以 不考虑输出结果的顺序 。

示例 1:

输入:nums1 = [1,2,2,1], nums2 = [2,2]
输出:[2]

示例 2:

输入:nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出:[9,4]
解释:[4,9] 也是可通过的

注:

  • 1 <= nums1.length, nums2.length <= 1000
  • 0 <= nums1[i], nums2[i] <= 1000

解题思路:

如果两个数组是有序的,则可以使用双指针的方法得到两个数组的交集。

首先对两个数组进行排序,然后使用两个指针遍历两个数组。可以预见的是加入答案的数组的元素一定是递增的,为了保证加入元素的唯一性,我们需要额外记录变量 pre 表示上一次加入答案数组的元素。

初始时,两个指针分别指向两个数组的头部。每次比较两个指针指向的两个数组中的数字,如果两个数字不相等,则将指向较小数字的指针右移一位,如果两个数字相等,且该数字不等于 pre ,将该数字添加到答案并更新 pre 变量,同时将两个指针都右移一位。当至少有一个指针超出数组范围时,遍历结束。

JavaScript 实现:

var intersection = function(nums1, nums2) {
nums1.sort((x, y) => x - y);
nums2.sort((x, y) => x - y);
const length1 = nums1.length, length2 = nums2.length;
let index1 = 0, index2 = 0;
const intersection = [];
while (index1 < length1 && index2 < length2) {
const num1 = nums1[index1], num2 = nums2[index2];
if (num1 === num2) {
// 保证加入元素的唯一性
if (!intersection.length || num1 !== intersection[intersection.length - 1]) {
intersection.push(num1);
}
index1++;
index2++;
} else if (num1 < num2) {
index1++;
} else {
index2++;
}
}
return intersection;
};

两个数组的交集 II

与 I 相通的类似的一道题:

给你两个整数数组 nums1 和 nums2 ,请你以数组形式返回两数组的交集。返回结果中每个元素出现的次数,应与元素在两个数组中都出现的次数一致(如果出现次数不一致,则考虑取较小值)。可以不考虑输出结果的顺序。

示例 1:

输入:nums1 = [1,2,2,1], nums2 = [2,2]
输出:[2,2]

示例 2:

输入:nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出:[4,9]

解题思路:

如果两个数组是有序的,则可以使用双指针的方法得到两个数组的交集。

首先对两个数组进行排序,然后使用两个指针遍历两个数组。

初始时,两个指针分别指向两个数组的头部。每次比较两个指针指向的两个数组中的数字,如果两个数字不相等,则将指向较小数字的指针右移一位,如果两个数字相等,将该数字添加到答案,并将两个指针都右移一位。当至少有一个指针超出数组范围时,遍历结束。

JavaScript 实现:

/**
* @param {number[]} nums1
* @param {number[]} nums2
* @return {number[]}
*/
var intersect = function(nums1, nums2) {
//将两个数组从小到大排序
nums1.sort((a,b) => a-b)
nums2.sort((a,b) => a-b)
let res = []
let key1 = 0, key2 = 0, index = 0
//在两个指针不达边界的前提下不断推进
while(key1 < nums1.length && key2 < nums2.length){
//判断nums1[key1]与nums2[key2]的大小,分出大于小于等于三种情况
if(nums1[key1] < nums2[key2]) key1++
else if(nums1[key1] > nums2[key2]) key2++
else{
res[index++] = nums1[key1]
key1++
key2++
}
}
return res
};

到此这篇关于JavaScript实现两个数组的交集 的文章就介绍到这了,更多相关JS数组交集 内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
js跨域问题浅析及解决方法优缺点对比
Nov 08 Javascript
jquery 中ajax执行的优先级
Jun 22 Javascript
表单验证正则表达式实例代码详解
Nov 09 Javascript
利用jQuery实现CheckBox全选/全不选/反选的简单代码
May 31 Javascript
JavaScript中子对象访问父对象的方式详解
Sep 01 Javascript
vue实现导航栏效果(选中状态刷新不消失)
Dec 13 Javascript
微信小程序 Animation实现图片旋转动画示例
Aug 22 Javascript
Vue.js递归组件实现组织架构树和选人功能案例分析
Jul 03 Javascript
jquery ajax 请求小技巧实例分析
Nov 11 jQuery
vue+element 实现商城主题开发的示例代码
Mar 26 Javascript
vue 子组件watch监听不到prop的解决
Aug 09 Javascript
小程序中手机号识别的示例
Dec 14 Javascript
angular4实现带搜索的下拉框
使用Canvas绘制一个游戏人物属性图
【js设计模式】SOLID五大设计原则
什么是SOLID
Vue3中toRef与toRefs的区别
Mar 24 #Vue.js
Javascript的promise,async和await的区别详解
Mar 24 #Javascript
一起来看看Vue的核心原理剖析
Mar 24 #Vue.js
You might like
mysql 中InnoDB和MyISAM的区别分析小结
2008/04/15 PHP
PHP多个版本的分析解释
2011/07/21 PHP
在PHP上显示JFreechart画的统计图方法
2013/11/03 PHP
Yii框架Session与Cookie使用方法示例
2019/10/14 PHP
Jquery Autocomplete 结合asp.net使用要点
2010/10/29 Javascript
javascript判断两个IP地址是否在同一个网段的实现思路
2013/12/13 Javascript
JQuery显示隐藏DIV的方法及代码实例
2015/04/16 Javascript
基于JavaScript FileReader上传图片显示本地链接
2016/05/27 Javascript
AngularJS基础 ng-href 指令用法
2016/08/01 Javascript
AngularJS通过$http和服务器通信详解
2016/09/21 Javascript
使用jQuery ajaxupload插件实现无刷新上传文件
2017/04/23 jQuery
详解如何在angular2中获取节点
2017/11/23 Javascript
jQuery实现基本淡入淡出效果的方法详解
2018/09/05 jQuery
Javascript 对象(object)合并操作实例分析
2019/07/30 Javascript
Angular处理未可知异常错误的方法详解
2021/01/17 Javascript
[01:11:10]2014 DOTA2华西杯精英邀请赛 5 24 iG VS VG加赛
2014/05/26 DOTA
Python爬取三国演义的实现方法
2016/09/12 Python
Ubuntu安装Jupyter Notebook教程
2017/10/18 Python
python实现12306抢票及自动邮件发送提醒付款功能
2018/03/08 Python
Python使用xlwt模块操作Excel的方法详解
2018/03/27 Python
django将图片上传数据库后在前端显式的方法
2018/05/25 Python
python中将\\uxxxx转换为Unicode字符串的方法
2018/09/06 Python
解决torch.autograd.backward中的参数问题
2020/01/07 Python
python orm 框架中sqlalchemy用法实例详解
2020/02/02 Python
python eventlet绿化和patch原理
2020/11/21 Python
详解Python Celery和RabbitMQ实战教程
2021/01/20 Python
详解Python中的GIL(全局解释器锁)详解及解决GIL的几种方案
2021/01/29 Python
泰国国际航空公司官网:Thai Airways International
2019/12/04 全球购物
迪斯尼假期(欧洲、中东及非洲):Disney Holidays EMEA
2021/02/15 全球购物
什么是SQL Server的确定性函数和不确定性函数
2016/08/04 面试题
行政经理的岗位职责
2013/11/23 职场文书
数学系毕业生的自我评价
2014/01/10 职场文书
精神文明单位申报材料
2014/05/02 职场文书
学生评语集锦
2015/01/04 职场文书
MySQL 数据类型选择原则
2021/05/27 MySQL
Python Pygame实战在打砖块游戏的实现
2022/03/17 Python