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 相关文章推荐
jquery实现TAB选项卡鼠标经过带延迟效果的方法
Jul 27 Javascript
使用jQuery Rotare实现微信大转盘抽奖功能
Jun 20 Javascript
微信小程序 wx.request(OBJECT)发起请求详解
Oct 13 Javascript
JS树形菜单组件Bootstrap TreeView使用方法详解
Dec 21 Javascript
详解从Node.js的child_process模块来学习父子进程之间的通信
Mar 27 Javascript
JavaScript mixin实现多继承的方法详解
Mar 30 Javascript
jQuery Form插件使用详解_动力节点Java学院整理
Jul 17 jQuery
Angular 5.0 来了! 有这些大变化
Nov 15 Javascript
Vuejs学习笔记之使用指令v-model完成表单的数据双向绑定
Apr 29 Javascript
JS块级作用域和私有变量实例分析
May 11 Javascript
vue与django集成打包的实现方法
Nov 11 Javascript
JS实现滑动拼图验证功能完整示例
Mar 29 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
PHP Cookie的使用教程详解
2013/06/03 PHP
深入解析PHP内存管理之谁动了我的内存
2013/06/20 PHP
php文件上传的例子及参数详解
2013/12/12 PHP
php模拟post上传图片实现代码
2016/06/24 PHP
PHP计算近1年的所有月份
2017/03/13 PHP
juqery 学习之四 筛选过滤
2010/11/30 Javascript
jQuery验证Checkbox是否选中的代码 推荐
2011/09/04 Javascript
JQuery操作Select的Options的Bug(IE8兼容性视图模式)
2013/04/21 Javascript
JavaScript中的索引数组、关联数组和静态数组、动态数组讲解
2014/11/08 Javascript
深入理解JavaScript系列(37):设计模式之享元模式详解
2015/03/04 Javascript
js获得当前系统日期时间的方法
2015/05/06 Javascript
原生js封装自定义滚动条
2017/03/24 Javascript
详解vue跨组件通信的几种方法
2017/06/15 Javascript
vue-swiper的使用教程
2018/08/30 Javascript
JS实现查找数组中对象的属性值是否存在示例
2019/05/24 Javascript
JS localStorage存储对象,sessionStorage存储数组对象操作示例
2020/02/15 Javascript
Python编程语言的35个与众不同之处(语言特征和使用技巧)
2014/07/07 Python
Python字典操作简明总结
2015/04/13 Python
利用Python2下载单张图片与爬取网页图片实例代码
2017/12/25 Python
Python使用gRPC传输协议教程
2018/10/16 Python
对DJango视图(views)和模版(templates)的使用详解
2019/07/17 Python
python+selenium+PhantomJS抓取网页动态加载内容
2020/02/25 Python
python新式类和经典类的区别实例分析
2020/03/23 Python
keras model.fit 解决validation_spilt=num 的问题
2020/06/19 Python
Python截图并保存的具体实例
2021/01/14 Python
EVE LOM英国官网:全世界最好的洁面膏
2017/10/30 全球购物
Spartoo比利时:欧洲时尚购物网站
2017/12/06 全球购物
分别介绍一下Session Bean和Entity Bean
2015/03/13 面试题
决心书范文
2014/03/11 职场文书
幼儿园大班毕业教师寄语
2014/04/03 职场文书
捐款活动总结
2014/08/27 职场文书
作风大整顿心得体会
2014/09/10 职场文书
个人对照检查材料思想汇报
2014/09/26 职场文书
2015年勤工助学工作总结
2015/04/29 职场文书
2016教师廉洁从教心得体会
2016/01/13 职场文书
JS 基本概念详细介绍
2021/10/16 Javascript