js计算器中如何解决数字重复问题

JavaScript05

js计算器中如何解决数字重复问题,第1张

可以使用js的for循环筛选实现去掉数组中的重复的数据。

需要准备的材料分别是:电脑、浏览器、ultraedit。1、在ue编辑器中新建一个空白的html文件,js文件。

2、在ue编辑器中输入以下html代码。3、在ue编辑器中输入以下js代码。4、编辑完成以后,在ue编辑器中点击保存,格式选择UTF8无BOM。5、在浏览器中打开此html文件,可以看到最终想要实现的去掉数组中的重复的数据效果。

可以使用双重循环,逐一对比元素,如有重复,则删除的方法去重。

其思路为

1、依来次遍历循环中的每一个元素。

2、对于任意一个元素,依次与之前的元素进行对比,如果有自重复则删除。

3、删除操作可以采用将后续元素逐个前移,达到覆盖当前元素的效果。

在此基础上可以进行一点优化,即,2113不需要每次删除元素均前移所有元素,而是把需要保留的元素放到"应该"放的位置即可,这样可以提高效率。5261

以整型数组4102为例,参考代码如下:

int remove_repeat(int *a, int l)//对起始地址为a,长度为l的数组进行去重,新的长度以返回值形式返回。

{

int i,j, r=0//i,j为循环下标,r为去重后1653元素总数,初始值为0

for(i = 0i <li ++)

{

for(j = 0j <rj ++)//检查是否重复

if(a[j] == a[i]) break

if(j == r) //没有重复元素

a[r++] = a[i]//将当前元素放置与去重后数组的尾部,并增加去重后的总数。

}

return r//返回新的长度。

}

方法1:

[js] view plain copy

Array.prototype.method1 = function(){

var arr[] //定义一个临时数组

for(var i = 0i <this.lengthi++){//循环遍历当前数组

//判断当前数组下标为i的元素是否已经保存到临时数组

//如果已保存,则跳过,否则将此元素保存到临时数组中

if(arr1.indexOf(this[i]) == -1){

arr.push(this[i])

}

}

return arr

}

方法2:

[js] view plain copy

Array.prototype.method2 = function(){

var h{} //定义一个hash表

var arr[] //定义一个临时数组

for(var i = 0i <this.lengthi++){//循环遍历当前数组

//对元素进行判断,看是否已经存在表中,如果存在则跳过,否则存入临时数组

if(!h[this[i]]){

//存入hash表

h[this[i]] = true

//把当前数组元素存入到临时数组中

arr.push(this[i])

}

}

return arr

}

方法3:

[js] view plain copy

Array.prototype.method3 = function(){

//直接定义结果数组

var arr[this[0]]

for(var i = 1i <this.lengthi++){//从数组第二项开始循环遍历此数组

//对元素进行判断:

//如果数组当前元素在此数组中第一次出现的位置不是i

//那么我们可以判断第i项元素是重复的,否则直接存入结果数组

if(this.indexOf(this[i]) == i){

arr.push(this[i])

}

}

return arr

}

方法4:

[js] view plain copy

Array.prototype.method4 = function(){

//将数组进行排序

this.sort()

//定义结果数组

var arr[this[0]]

for(var i = 1i <this.lengthi++){//从数组第二项开始循环遍历数组

//判断相邻两个元素是否相等,如果相等说明数据重复,否则将元素写入结果数组

if(this[i] !== arr[arr.length - 1]){

arr.push(this[i])

}

}

return arr

}