JS编程训练 | 题11:查找重复元素
2017-07-14 00:03
316 查看
题目描述
找出数组 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; }
相关文章推荐
- JS编程训练 | 题13:查找元素位置
- js:查找重复元素
- JS编程训练 | 题5:删除最后一个元素
- JS查找数组中重复元素的方法详解
- JS编程训练 | 题3:移除数组中的元素
- JS编程训练 | 题7:数组前删除第一个元素
- JS 之 查找数组中重复的元素
- JS编程训练 | 题4:数组中添加元素
- JS编程训练 | 题9:添加元素
- JS编程训练 | 题1:查找数组元素位置
- js 查找数组重复元素方法
- js 查找页面重复元素
- JS编程训练 | 题6:数组前插入元素
- js去掉重复的元素
- js javascript 根据类名称查找所有元素
- js去掉数组中的重复元素
- js过滤数组重复元素的简单方法
- JS中取数组中重复的元素和去除重复的元素
- js 删除数组重复元素
- Dynamics CRM 2011 编程系列(11):JS编程之征服表单控件(一)