您好,欢迎访问一九零五行业门户网

javascript数组去重/查找/插入/删除的方法

数组去重原型方法//---------------first--------------- array.prototype.distinct = function(){ var arr=[]; var obj={}; //对象承接 for(var i=0,len=this.length;i<len;i++){ if(!obj[this[i]]){ obj[this[i]]=1; arr.push(this[i]); } } return arr; }; var arr = new array(); arr.push(1,3,2,4,4,4,5,6,7,8,8,8,9,0); //--------------second---------------- array.prototype.distinct = function(){ var arr=[]; for(var i=0,len=this.length;i<len;i++){ if(this[i]==this[i+1]){ continue; }else{ arr.push(this[i]); } }  return arr; }; var arr = new array(); arr.push(1,3,2,4,4,4,5,6,7,8,8,8,9,0); //----------------third---------------- array.prototype.distinct = function(){ for(var i=0,len=this.length;i<len;i++){ for(var j=i+1;j<=len;j++){ if(this[i]==this[j]){ console.log(this[j]); this.splice(j,1); j--; //得考虑如果删除一个元素,j的值需要减1 len--; } } } //return this; }; var arr = new array(); arr.push("a","b","c","c","b","bb","dd","d","aa","c","bb"); arr.distinct();
普通方法function removerepeat(arr){  var array=[];  var obj={};  for(var i=0,len=arr.length;i<len;i++){ if(!obj[arr[i]]){ obj[arr[i]]=1; array.push(arr[i]); }  }  return array; }; var arr = new array(1,3,2,4,4,4,5,6,7,8,8,8,9,0); var array = removerepeat(arr);
数组查找顺序查找function sequencesearch(arr, value){ var i; for(i=0; i<arr.length; i++){ if(arr[i]==value) return i; } return -1; }
二分查找二分查找元素必须是有序的,如果是无序的则要先进行排序操作
-------------折半查找-------------- function binarysearch1(arr, value){ var low, high, mid; low = 0; high = arr.length-1; while(low<=high){ mid = math.floor((low+high)/2); if(a[mid]==value){ return mid; } if(a[mid]>value){ high = mid-1; } if(a[mid]<value){ low = mid+1; } } return -1; } -------------递归版本-------------- function binarysearch2(arr, value){ var low, high, mid; low = 0; high = arr.length-1; var mid = low+(high-low)/2; if(arr[mid]==value){ return mid; } if(a[mid]>value){ return binarysearch2(arr, value); } if(a[mid]<value){ return binarysearch2(arr, value); } }
数组插入顺序插入//----------------first---------------- function insert(arr, n, data){ //若插入数据位置不在表尾 if (n < arr.length){ //将要插入位置之后元素依次向后移动一位 for (var i = seqlist.listlen - 1; i >= n; i--) { seqlist.listdata[i + 1] = seqlist.listdata[i]; } } //将数据插入到位置为n的位置并将数组的长度加1 seqlist.listdata[n-1] = data; seqlist.listlen++; return true; } //----------------second---------------- function aa(arr, val) { for (var i = 0; i <arr.length; i++) { if (arr[i] == val) return i; } return -1; }; function bb(arr, val) { var index =arr.indexof(val); if (index > -1) { arr.splice(index, 1); } }; var emp = ['abs','dsf','sdf','fd'] bb(emp, 'fd');
数组删除function delete(arr, n){ //判断数组是否为空 if (seqlist.listlen == 0) return false; //判断n的位置是否合法 if (n < 1 || n > seqlist.listlen) return false; //如果删除不是最后位置 if (n < seqlist.listlen) { //将删除位置后继元素依次前移 for (int i = n; i < seqlist.listlen; i++) { seqlist.listdata[i-1] = seqlist.listdata[i]; } } //表长减1 seqlist.listlen--; return true; }
以上就是javascript数组去重/查找/插入/删除的方法的详细内容。
其它类似信息

推荐信息