当前位置: 首页 > news >正文

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);
arr.distinct();

//----------------second----------------
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--;
        }
      }    
    }
};
var arr = new Array();
arr.push("a","b","c","c","b","bb","dd","d","aa","c","bb");
arr.distinct();

//只适用于已经排序的数组,数组排序方法可参见另外一篇博客
 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);
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;
}

相关文章:

  • unity3d 调用C#的dll文件
  • JAVA的多线程
  • virtualenv安装问题
  • Qmail+Vpopmail 安装相关文档
  • as2 针对加载进来的swf操作
  • 设置IE浏览器默认的下载路径
  • Centos 7下nginx开机自启动脚本
  • 第一章:The Missing Code Library--3.正常化日期格式
  • [Step By Step]在SAP Business Objects Data Services中使用SQL Transform将数据导入到SAP HANA中(SQL Transform)...
  • RTOS姊妹花——Small RTOS与STOS++简介
  • 微服务架构适用场景分析
  • 尚科推广专家当于同行的一款独立软式解决方案
  • 《Typecript 入门教程》 3、接口
  • 《把时间当朋友》 读书笔记
  • 在开发中你可能没有考虑到的两个性能优化
  • 【RocksDB】TransactionDB源码分析
  • java 多线程基础, 我觉得还是有必要看看的
  • opencv python Meanshift 和 Camshift
  • React-Native - 收藏集 - 掘金
  • v-if和v-for连用出现的问题
  • vue从创建到完整的饿了么(18)购物车详细信息的展示与删除
  • 分布式任务队列Celery
  • 让你的分享飞起来——极光推出社会化分享组件
  • 如何打造100亿SDK累计覆盖量的大数据系统
  • 白色的风信子
  • SAP CRM里Lead通过工作流自动创建Opportunity的原理讲解 ...
  • 东超科技获得千万级Pre-A轮融资,投资方为中科创星 ...
  • 曜石科技宣布获得千万级天使轮投资,全方面布局电竞产业链 ...
  • ​​快速排序(四)——挖坑法,前后指针法与非递归
  • #define与typedef区别
  • #NOIP 2014#day.2 T1 无限网络发射器选址
  • #我与Java虚拟机的故事#连载15:完整阅读的第一本技术书籍
  • (06)Hive——正则表达式
  • (1)(1.9) MSP (version 4.2)
  • (Matlab)基于蝙蝠算法实现电力系统经济调度
  • (ros//EnvironmentVariables)ros环境变量
  • (二)基于wpr_simulation 的Ros机器人运动控制,gazebo仿真
  • (附源码)ssm跨平台教学系统 毕业设计 280843
  • (附源码)计算机毕业设计ssm基于B_S的汽车售后服务管理系统
  • (紀錄)[ASP.NET MVC][jQuery]-2 純手工打造屬於自己的 jQuery GridView (含完整程式碼下載)...
  • (经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路
  • (原創) 是否该学PetShop将Model和BLL分开? (.NET) (N-Tier) (PetShop) (OO)
  • (转) SpringBoot:使用spring-boot-devtools进行热部署以及不生效的问题解决
  • ****** 二 ******、软设笔记【数据结构】-KMP算法、树、二叉树
  • .net 简单实现MD5
  • .NET 中小心嵌套等待的 Task,它可能会耗尽你线程池的现有资源,出现类似死锁的情况
  • .Net中wcf服务生成及调用
  • .sys文件乱码_python vscode输出乱码
  • @JoinTable会自动删除关联表的数据
  • @RequestBody的使用
  • [ Linux Audio 篇 ] 音频开发入门基础知识
  • [ 隧道技术 ] 反弹shell的集中常见方式(四)python反弹shell
  • [android] 练习PopupWindow实现对话框
  • [BSGS算法]纯水斐波那契数列
  • [C/C++]数据结构 深入挖掘环形链表问题