JavaScript数据结构和算法简述——数组

464 查看

为什么先讲数组


数据结构可以简单的被分为线性结构和非线性结构。

线性结构大致包括:

  1. 数组(连续存储);
  2. 链表(离散存储);
  3. 栈(线性结构常见应用,由链表或数组增删和改进功能实现);
  4. 队列(线性结构常见应用,由链表或数组增删和改进功能实现);

非线性结构大致包括:

  1. 树;
  2. 图;

其中,数组是应用最广泛的数据存储结构。它被植入到大部分编程语言中。由于数组十分容易懂,所以它被用来作为介绍数据结构的起点非常合适。

JavaScript数组基础知识


在ECMAScript中数组是非常常用的引用类型了。ECMAScript所定义的数组和其他语言中的数组有着很大的区别。那么首先要说的就是数组在js中是一种特殊的对象。

特点:

  1. 数组是一组数据的线性集合;
  2. js数组更加类似java中的容器。长度可变,元素类型也可以不同;
  3. 数组的长度可以随时修改(length属性);

常用操作方法:

  • push、pop
  • shift、unshift
  • splice、slice
  • concat、join、sort、reverse等

JavaScript数组操作


一、 数组方法:

1、 数组的创建

注意:虽然第三种方法创建数组指定了长度,但实际上所有情况下数组都是变长的,也就是说即使指定了长度为5,仍然可以将元素存储在规定长度以外的,并且这时长度会随之改变。

2、 数组元素的访问

3、 数组元素的添加

4、 数组元素的删除

5、 数组的合并

6、 数组的拷贝

7、 数组元素的排序

8、 数组元素的字符串化