JS基于开关思想实现的数组去重功能【案例】

本文实例讲述了JS基于开关思想实现的数组去重功能。分享给大家供大家参考,具体如下:

场景: 比如给你一个数组var Arr = [ 25, 70, 60, 70, 65, 65, 80 ],最终要得到去重后的新数组[25,70,60,65,80].

思路:

1.先定义个空的新数组newArr;

2.遍历旧数组Arr 中所有元素;

3.定义一个isZai变量表示开关,默认为false状态;

4.遍历新数组所有元素与旧数组元素比较(Arr[ i ] == newArr[ j ]);

5.如果该元素存在于新数组中,则改变开关状态为true;

6.根据开关状态实现需求:如果开关为false状态,则将旧数组的元素添加到新数组中;

7.最后打印新数组

js代码如下

<script>

var Arr = [ 25, 70, 60, 70, 65, 65, 80 ];//最终得到[25,70,60,65,80]

//1.先定义个空的新数组newArr;

var newArr=[];

//2.遍历旧数组Arr 中所有元素;

for(var i=0;i<=Arr.length;i++){

//3.定义一个isZai变量表示开关,默认为false状态;

var isZai=false;

for(var j=0;j<=newArr.length;j++){

// 4.遍历新数组所有元素与旧数组元素比较(Arr[ i ] == newArr[ j ]);

if(Arr[ i ] == newArr[ j ]){

//5.如果该元素存在于新数组中,则改变开关状态为true;

isZai=true;//假设被推翻

break;//一旦重复后面没有比较必要

}

}

// 6.根据开关状态实现需求:如果开关为false状态,则将旧数组的元素添加到新数组中;

if(isZai==false){

newArr[newArr.length]=Arr[i];

}

}

console.log ( newArr )//打印新数组[25,70,60,65,80]

</script>

使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试上述代码,可得如下运行结果:

PS:这里再为大家提供几款相关工具供大家参考使用:

在线去除重复项工具:

http://tools.jb51.net/code/quchong

在线文本去重复工具:

http://tools.jb51.net/aideddesign/txt_quchong

更多关于JavaScript相关内容还可查看本站专题:《JavaScript数组操作技巧总结》、《JavaScript字符与字符串操作技巧总结》、《JavaScript遍历算法与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript错误与调试技巧总结》

希望本文所述对大家JavaScript程序设计有所帮助。

以上是 JS基于开关思想实现的数组去重功能【案例】 的全部内容, 来源链接: utcz.com/z/312790.html

回到顶部