JS编程训练 | 题11:查找重复元素
来源:互联网 发布:保留数据重置win10 编辑:程序博客网 时间:2024/06/01 20:34
题目描述
找出数组 arr 中重复出现过的元素
示例1
输入[1, 2, 4, 4, 3, 3, 1, 5, 3]
输出[1, 3, 4]
思路一:哈希数组
function duplicates(arr) { //Step1:定义数组hasharr用来存放重复的次数,ans用来存放结果 var hasharr = [], ans = []; //第一遍遍历arr完善哈希表 for(var i = 0; i < arr.length; i++){ if(!hasharr[arr[i]]){ hasharr[arr[i]] = 1; }else{ hasharr[arr[i]]++; } } //第二遍遍历哈希表把重复次数大于1的值push进ans数组 for(var index in hasharr){ if(hasharr[index] > 1){ ans.push(index); } } return ans;}
思路二:排序后前后比对
function duplicates(arr) { //先排序,如果后一个与前一个相等且未保存,则保存。 var ans = []; arr.sort(); for(var i = 1; i < arr.length; i++){ if(arr[i] == arr[i-1] && ans.indexOf(arr[i]) == -1){ ans.push(arr[i]); } } return ans;}
思路三:forEach + indexOf + lastIndexOf
function duplicates(arr) { var ans = []; arr.forEach(function(val){ if(arr.indexOf(val) != arr.lastIndexOf(val) && ans.indexOf(val) == -1){ ans.push(val); } }); return ans;}
阅读全文
0 0
- JS编程训练 | 题11:查找重复元素
- JS编程训练 | 题1:查找数组元素位置
- JS编程训练 | 题13:查找元素位置
- js:查找重复元素
- JS编程训练 | 题9:添加元素
- js 查找数组重复元素方法
- JS编程训练 | 题3:移除数组中的元素
- JS编程训练 | 题4:数组中添加元素
- JS编程训练 | 题5:删除最后一个元素
- JS编程训练 | 题6:数组前插入元素
- [编程题] 消除重复元素
- [编程题] 消除重复元素
- JS 之 查找数组中重复的元素
- 查找重复元素
- 查找重复元素
- JS编程训练 | 题7:数组前删除第一个元素
- 查找数组重复的元素
- 2017 网易 [编程题] 消除重复元素
- JAVA简介、方法、面向对象笔记1
- Minimal 下配置防火墙配置文件
- 【剑指offer】面试题9:用两个栈实现队列
- 线性判别分析LDA
- Maven工程聚合,多个Java工程、web工程聚合
- JS编程训练 | 题11:查找重复元素
- 深度增强学习前沿算法思想【DQN、A3C、UNREAL,简介】
- has_many through(多对多) 与polymorphic(多态)混合使用
- php 接口与前端数据交互实现
- 【剑指offer】面试题10:斐波那契数列
- AAC-封装格式
- python 高级特性
- echarts折线图柱状图的坐标轴的颜色及样式的设置
- Python编程_Lesson005_元组