首页 > 编程语言 >【算法学习前置】了解JS中的数组

【算法学习前置】了解JS中的数组

时间:2023-05-24 16:12:26浏览次数:39  
标签:arr 元素 console log 前置 JS 算法 数组 const

介绍

此篇属于前端算法入门系列的第一篇,主要介绍常用的数组方法字符串方法遍历方法高阶函数正则表达式以及相关数学知识

文章主要包含以下内容:

  • 数组常用方法
  • 字符串常用方法
  • 常用遍历方法&高阶函数
  • 常用正则表达式
  • 数学知识

一、数组常用方法

  1. push()

    在尾部追加,类似于压栈。push操作会改变原数组,数组长度+1。

    const arr = [1, 2, 3]
    arr.push(8)
    console.log(arr) // [1, 2, 3, 8]
    
  2. pop()

    将数组中,最后一个元素弹出,类似于出栈,pop()操作会改变原数组,数组长度-1。

    const arr = [1, 2, 3, 8]
    arr.pop()
    console.log(arr) // [1, 2, 3]
    
    // 用数组方法,模拟栈操作
    const stack = [0, 1]
    stack.push(9) // 入栈
    console.log(stack) // [0, 1, 9]
    
    stack.pop() // 出栈
    console.log(stack) // [0, 1]
    
  3. unshift()

    往数组头部插入一个元素,unshift()操作会改变原数组,数组长度+1。

    const arr = [1, 2, 3]
    arr.shift(9)
    console.log(arr) // 9, 1, 2, 3
    
  4. shift()

    将数组中,第一个元素弹出,shift()操作会改变原数组,数组长度-1。配合unshft()可以模拟队列数据结构

    const arr = [1, 2, 3]
    arr.unshift()
    console.log(arr) // [2, 3]
    
    // 模拟常见数据结构之一:队列
    const queue = [0, 1]
    queue.push(2) // 入队
    console.log(queue) // [0, 1, 2]
    
    const shiftValue = queue.shift() // 出队
    console.log(shiftValue) // 0
    console.log(queue) // [1, 2]
    
  5. concat()

    合并连个数据,将传入数组拼接至目标数组的尾部,该操作会返回一个新数组,不会改变原有数组。

    const arr1 = [1, 2, 3]
    const arr2 = [4, 5, 6]
    const arr3 = arr1.concat(arr2)
    console.log(arr) // [1, 2, 3]
    console.log(arr2) // [4, 5, 6]
    console.log(arr3) // [1, 2, 3, 4, 5, 6]
    
  6. indexOf()

    在数组中寻找指定元素,可以找到就返回该元素的下标,找不到则返回-1;注意,如果存在多个匹配元素,至会返回靠前的元素下标。

    const arr = [1, 2]
    console.log(arr.indexOf(2)) // 1
    console.log(arr.indexOf(9)) // -1
    
  7. includes()

    在数组中寻找指定元素,如果存在该元素,则返回true,否则返回false

    const arr = [1, 2, 3]
    console.log(arr.includes(2)) // true
    console.log(arr.includes(4)) // false
    
  8. join()

    将数组转换为字符串,并返回字符串,不传值默认用,分隔元素,原数组不变。

    const arr = [1, 2, 3]
    const str = arr.join()
    console.log(str) // 1,2,3
    
  9. reverse()

    翻转原数组,并返回已完成翻转的数组,原数组会被改变。

    const arr = [1, 2, 3]
    console.log(arr.reverse()) // [3, 2, 1]
    console.log(arr) // [3, 2, 1]
    
  10. slice(start,end)

    start 截取数组至 end ,但不包含end。slice()操作不会更改原数组。

    const arr = [1, 3, 4, 6, 7, 9]
    console.log(arr.slice(0,3)) // [1, 3, 4]
    console.log(arr) // [1, 3, 4, 6, 7, 9]
    
  11. splice(start,deleteCount,item1,item2...)

    移除或者替换已存在的元素 和/或 添加新元素

    • start 参数表示操作开始位置
    • deleteCount 参数表示需要截取的元素个数
    • item 为 要添加的元素

    如果deleteCount0,则表示不删除元素,从start位置开始添加后面的几个元素到原始的数组里面。

    splice() 返回值为由被删除的元素组成的一个数组,如果没有删除元素,则返回一个空数组

    splice()方法这个方法会改变原始数组,数组的长度会发生变化

    const arr1 = [1, 2, 3]
    const arr2 = arr1.splice(1, 0, 2, 3, 4) // 从第二位,不删除元素,插入2,3,4
    console.log(arr2) // []
    console.log(arr1) // [1, 2, 3, 4, 2, 3]
    
  12. sort()

    • 对数组的元素进行排序,并返回数组。
    • 默认排序顺序是在将元素转换为字符串,然后比较它们的UTF-16代码单元值序列时构建的。
    • 由于它取决于具体实现,因此无法保证排序的时间和空间复杂性。
    // 默认排序
    const arr = [3, '2', 'F', 'A']
    console.log(arr.sort()) // ['2', 3, 'A', 'F']
    
    // 自定义排序 (由大到小)
    const arr = [6,7,2,3,9,1,3,5]
    console.log(arr.sort((a,b) => b - a))
    
  13. toString()

    将数组转化成字符串,并返回该字符串,逗号隔开,原数组不变。

    const arr = [1, 2, 3, 4, 5]
    console.log(arr.toString()) // ‘1, 2, 3, 4, 5’
    console.log(arr) // [1, 2, 3, 4, 5]
    

标签:arr,元素,console,log,前置,JS,算法,数组,const
From: https://www.cnblogs.com/mosaicMask/p/17428623.html

相关文章

  • 【算法学习前置】了解js中的字符串
    二、字符串常用方法chat()返回指定索引位置处的字符。类似于数组用中括号获取相应下标位置的数据。conststr='abcdef'console.log(str.chat(2))//'c'console.log(srt[2])//'c'concat()类似数组的concat(),用来返回一个合并拼接两个或两个以上字符串。原字符串不......
  • geojson格式数据
    可以通过一下地址验证https://geojson.io/#map=11.2/38.2756/116.7917一个面数据的情况,features是一个数组,geometry的type=Polygon表示一个面数据,可以存放多个面数据,以下就存放了一个面{"type":"FeatureCollection","features":[{"type":&quo......
  • 【Kafka从入门到成神系列 三】Kafka 生产者消息分区及压缩算法
    ......
  • 搜索算法
    //DPS(深度搜索)//n-皇后问题//方法一(与数字全排列相似)#include<bits/stdc++.h>usingnamespacestd;constintN=80;intn,res=0;charQ[N][N];boolcow[N],dg[N],rdg[N];//dg,rdg是对角线和反对角线,cow是列;voiddfs(intu){if(u==n){res++;......
  • 基础算法大全(更新ing
    1前缀和///给定一组数,求任意区间的总和#include<bits/stdc++.h>usingnamespacestd;constintN=100010;intn,a[N],s[N],m;intmain(){cin>>n>>m;for(inti=1;i<=n;i++){cin>>a[i];s[i]=s[i-1]+a[i];}whil......
  • 贪心算法
    //区间选点//数轴上有n个闭区间[a_i,b_i]。取尽量少的点,使得每个区间内都至少有一个点(不同区间内含的点可以是同一个)////Input//第一行1个整数N(N<=100)//第2~N+1行,每行两个整数a,b(a,b<=100)//INPUT:2//15//46//OUTPUT:1#include<bits/stdc++.h>usingnamespace......
  • js select下拉框选取默认学期
    termList.map(item=>{if(item.isOnTerm==1){termOpts+='<optionvalue="'+item.termId+'"selected>'+item.termName+'</option>';}else{......
  • 自定义注解实现数据序列化时进行数据脱敏(基于springboot默认jackjson)、消息转换器
    消息转换器fastjson与jackjson问题在springboot中使用fastjson的@jsonField无效原因:在springboot默认有json(jackjson)解析工具,所以使用fastjson不会生效解决方案替换默认的解析工具(笔者不推荐,这里根据自己项目决定)fastjson替换默认的jackjson第一种方法bean方法packagecom......
  • java将wkt面数据转geojson和elasticsearch的shape数据
    wkt面数据转geojsonimportcom.alibaba.fastjson.JSONException;importcom.alibaba.fastjson.JSONObject;importorg.locationtech.jts.geom.Coordinate;importorg.locationtech.jts.geom.Geometry;importorg.locationtech.jts.io.ParseException;importorg.location......
  • day104 - jsp语法
    jsp标签页面包含标签(类似vue组件)<%--jsp:include--%><jsp:includepage="jsptag2.jsp"></jsp:include> 请求转发标签其中param可以携带参数<%--请求转发标签--%>页面一:请求转发到页面二<jsp:forwardpage="/jsptag2.jsp"><jsp:paramna......