分析:首先设置一个空数组,两个指针,其中一个指针从第一个开始遍历Array元素,另一个指针从它的下一个开始遍历Array元素,判断这两个指针所指元素是否相等,如果相等则把这个元素push在空数组中;如果不相等,则第二个指针向后挪一位,在进行判断,直到挪到最后一位则判断完毕。再从第一个指针向后挪一位开始判断......如此循环。
代码实现如下:
Array.prototypr.distinct(){
var res = []
for(var i = 0 ; i<this.length ; i++){
for(var j = i+1;i<this.length){
if(this[i]===this[j]){
res.push(this.splice(j,i)[0])
//这步骤是最重要的this.splice(j,1)删除重复的元素,splice返回的是被删除的数组,
//加[0]就是这个被删除的元素,ret.push(这个元素),把这个重复的元素加入到数组ret中
}else{
j++
}
}
}
return res;
}
一个方法实现:mySort()能使传入的参数按照从小到大的顺序显示出来。
function mySort() {
var tags = new Array();
for(var i = 0;i < arguments.length;i++) {
tags.push(arguments[i]);
}
tags.sort(function(compare1,compare2) {
return compare1- compare2;
});
return tags;
}
var result = mySort(50,11,16,32,24,99,57,100);
console.info(result);