数组是平时使用最经常使用的数据结构,在JavaScript中数组是动态的分配大小,在这里我不会介绍JavaScript里面数组的全部的方法,而是针对数据结构这个方向谈谈所用到的方法。javascript
//建立空数组
var array = new Array();
//[]
//初始化数组
var array = new Array(1,2,3);
var array = Array.of(1,2,3);//ES6的方法
//[1,2,3]
//建立大小为5的数组
var array = new Array();//ES6的方法
//[undefined,undefined,undefined,undefined,undefined]
//给数组赋值
var array = new Array();
array[0] = 1 ;
array[1] = 2 ;
array[2] = 3 ;
//[1,2,3]复制代码
var number = [1,2,3];
number[number.length] = 4;
//[1,2,3,4]
//或者
var number = [1,2,3];
number.push(4);
//[1,2,3,4]复制代码
var number = [1,2,3];
number.unshift(0);
//[0,1,2,3]
number.unshift(-2,-1);
//[-2,-1,0,1,2,3]复制代码
运用splice方法java
//在索引1后面添加2,3,4
var number = [1,5,6];
number.splice(1,0,2,3,4);
//[1,2,3,4,5,6]复制代码
var number = [1,2,3];
number.shift();
//[2,3]复制代码
使用splice方法删除数组任意位置的元素git
var numebr = [1,2,3,4,5,6];
//若是想删除元素3
number.splice(2,1);
//[1,2,4,5,6]
//若是想删除元素4,5
number.splice(3,2);复制代码
var number = [3,2,1];
number.reverse();
//[1,2,3]复制代码
var numebr = [2,3,4,1,3,7];
number.sort();
//[1,2,3,3,4,7]复制代码
这个自定义排序跟java里面实现comparator接口一个意思。用处可大了。github
var number = [4,5,6,7,1,2,3,8,9,10,11,12,13];
number.sort();
//[1, 10, 11, 12, 13, 2, 3, 4, 5, 6, 7, 8, 9]复制代码
仿佛看起有点不对啊,咱们应该想要的是
[1,2,3,4,5,6,7,8,9,10,11,12,13],这个时候咱们就用自定义排序来解决这个问题数组
var number = [4,5,6,7,1,2,3,8,9,10,11,12,13];
function compare(a,b){
if(a < b){
return -1;
}
if(a > b){
return 1;
}
return 0;
}
number.sort(compare);
//[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13]复制代码
这还只是最简单的,也能够对任何对象类型进行数组排序。例如,对象Person有名字和年龄属性,咱们但愿根据年龄排序数据结构
var friends = [{name:'李晨',age:40},{name:'范冰冰',age:35}];
function comparePerson(a,b){
if(a.age < b.age){
return -1;
}
if(a.age > b.age){
return 1;
}
return 0;
}
friends.sort(comparePerson);
//[{name:'范冰冰',age:35},{name:'李晨',age:40}]复制代码
搜索有两个方法:indexOf方法返回与参数匹配的第一个元素的索引,lastIndexOf返回与参数匹配的最后一个元素的索引。函数
var number = [1,3,4,3,56,6,7,4];
number.indexOf(3);//1
number.lastIndexOf(3)//3复制代码
栈是一种遵循后进先出(LIFO)原则的有序集合。新添加的或待删除的元素都保存在栈的末尾,称做栈顶,另外一端就叫栈底。在栈里,新元素都靠近栈顶,旧元素都接近栈底。在JavaScript中变量保存和函数调用都是用栈存储的。ui
首先建立一个类来表示一个栈,须要一种数据结构来保存栈里的元素。这里咱们就选择刚学的数组:var items = [];
接下来,为咱们的栈声明一些方法:this
若是上一节数组认真看了,我相信用JavaScript实现一个栈是很是简单的。在这里就直接来代码了,不用一个方法一个方法去解释了。spa
function Stack(){
var items = [];
this.push = function(element){
items.push(element);
}
this.pop = function(){
return items.pop();
}
this.peek = function(){
return items[items.length-1];
}
this.isEmpty = function(){
return items.length === 0;
}
this.size = function(){
return items.length;
}
this.clear = function(){
items = [];
}
this.print = funciton(){
console.log(items.toString());
}
}复制代码
队列是遵循先来先服务(FIFO)原则的一组有序的项。队列在尾部添加新元素,并从顶部移除元素。最新添加的元素排在队列的末尾。
在现实生活中常见的例子就是排队。
在计算机科学中,一个常见的例子就是打印队列,先点击打印的文档会被先打印。
一样先建立一个类来表示一个队列。须要用到的数据结构一样是数组var items = [];
声明可用的方法:
function Queue(){
var items = [];
this.enqueue = function(element){
items.push(element);
}
this.dequeue = function(){
return items.shift();
}
this.front = function(){
return items[0];
}
this.isEmpty = function(){
return items.length === 0;
}
this.clear = function(){
items = [];
}
this.size = funciton(){
return items.length;
}
this.print = function(){
console.log(items.toString());
}
}复制代码
在优先队列中,元素被赋予优先级。当访问元素的时,具备最高优先级的元素先删除。优先队列具备最高进先出的行为特征。例如:医院的急救室为病人赋予优先级(这个优先级能够指病情严重的成程度),具备最高优先级的病人最早获得治疗。
实现一个优先队列有两种选项:
咱们这里采用第一种。
function PriorityQueue(){
var items = [];
funciton QueueElement(element,priority){
this.element = element;
this.priority = priority;
}
function comparePriority(a,b){
if(a.priority > b.priority){
return 1;
}
if(a.priority < b.priority){
return -1;
}
return 0;
}
this.enqueue = funciton(element,priority){
var queueElement = new QueueElement(element,priority);
items.push(queueElement);
items.sort(comparePriority);
}
//其它方法和默认的Queue实现相同
}复制代码
固然,这个enqueue的实现方法不少种,我这效率不是最高的,可是容易理解。将插入的元素根据优先级排个序,那么先出去的就是优先级最高的了。
这几个数据结构比较简单,因此我没有举例子,下一次分享的是链表,敬请期待!最后欢迎访问个人我的站点!