当前位置: 首页 > 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、接口
  • 《把时间当朋友》 读书笔记
  • 在开发中你可能没有考虑到的两个性能优化
  • 【前端学习】-粗谈选择器
  • 2017-09-12 前端日报
  • extract-text-webpack-plugin用法
  • javascript从右向左截取指定位数字符的3种方法
  • PAT A1120
  • React+TypeScript入门
  • SpiderData 2019年2月25日 DApp数据排行榜
  • weex踩坑之旅第一弹 ~ 搭建具有入口文件的weex脚手架
  • 阿里云爬虫风险管理产品商业化,为云端流量保驾护航
  • 给新手的新浪微博 SDK 集成教程【一】
  • 如何使用 OAuth 2.0 将 LinkedIn 集成入 iOS 应用
  • 思否第一天
  • 小程序01:wepy框架整合iview webapp UI
  • 小而合理的前端理论:rscss和rsjs
  • 用element的upload组件实现多图片上传和压缩
  • python最赚钱的4个方向,你最心动的是哪个?
  • #pragam once 和 #ifndef 预编译头
  • ${factoryList }后面有空格不影响
  • (32位汇编 五)mov/add/sub/and/or/xor/not
  • (六) ES6 新特性 —— 迭代器(iterator)
  • (生成器)yield与(迭代器)generator
  • (译)2019年前端性能优化清单 — 下篇
  • (转)程序员技术练级攻略
  • .NET Core工程编译事件$(TargetDir)变量为空引发的思考
  • .NetCore实践篇:分布式监控Zipkin持久化之殇
  • .net企业级架构实战之7——Spring.net整合Asp.net mvc
  • :“Failed to access IIS metabase”解决方法
  • @vue/cli 3.x+引入jQuery
  • []AT 指令 收发短信和GPRS上网 SIM508/548
  • [Angular] 笔记 20:NgContent
  • [AutoSar]BSW_Com07 CAN报文接收流程的函数调用
  • [CLR via C#]11. 事件
  • [HCTF 2018]WarmUp (代码审计)
  • [Linux版本Debian系统]安装cuda 和对应的cudnn以cuda 12.0为例
  • [MySQL复制异常]Cannot execute statement: impossible to write to binary log since statement is in row for
  • [Prism]Composite Application Guidance for WPF(9)——命令
  • [Python设计模式] 第27章 正则表达式——解释器模式
  • [RK-Linux] 移植Linux-5.10到RK3399(四)| 检查HDMI配置与打开内核LOGO显示
  • [ubuntu]split命令分割文件
  • [技术八卦]放毒记