案例:开关思想实现数组的去重

场景: 比如给你一个数组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>

猜你喜欢

转载自blog.csdn.net/xiaodi520520/article/details/82952458
今日推荐