学习javascript数据结构和算法

Posted blancher

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了学习javascript数据结构和算法相关的知识,希望对你有一定的参考价值。

一 、数组

1、迭代数组(斐波那契数列循环)

var fibonacci = [];
fibonacci[1] = 1;
fibonacci[2] = 2;

for(var i = 3;i < 20;i++){
    fibonacci[i] = fibonacci[i-1] +fibonacci[i-2];
}

2、数组操作

push()   //添加元素到数组末尾

unshift() //添加元素到数组首位

pop()  //删除数组最后元素

shift() //删除数组首位元素

splice(5,3,2,3,4)  //从索引5开始删除3个元素,并开始添加元素2,3,4.

***多为数组迭代用多重循环

3、数组方法

合并

  • concat()     //连接数组并返回结果

迭代

every()       //对数组的每一项运行给定函数,若都返回ture则返回true

  • some()          //对数组的每一项运行给定函数,若任一项返回ture则返回true
  • filter()         //对数组的每一项运行给定函数,返回true的项组成的数组
  • forEach()   //对数组的每一项运行给定函数,无返回值
  • map()             //对数组的每一项给定函数,返回每次函数调用的结果组成的数组
  • reduce()      //previousValue、currentValue、index和array四个参数进行求和

排序

  • reverse()        //颠倒数组元素的顺序
  • sort()           //按照字母顺序排序,也可根据排序方法进行排序

搜索

  • indexOf()   //返回第一个与给定参数相等的元素索引,没有找到则返回-1
  • lastIndexOf()   //返回在数组中搜索道德与参数相等的元素的索引的最大值
  • slice()          //传入索引值,将数组里对应索引范围内的元素作为新数组返回

输出为字符串

  • toString()      //将数组作为字符串返回
  • valueOf()     //将数组作为字符串返回
  • join()          //将所有元素连成字符串

***es6数组的新功能

(1)使用forEach和箭头函数迭代

number.forEach(x => {
    console.log((x % 2 == 0))
})

(2)使用for...of循环迭代

for(let n in number){
   console.log((n % = 2) ? ‘even‘ : ‘odd‘);
}

(3)@@iterator属性

entries()   //返回包含键值对的@@interator

let aEntries = numbers.entries();
console.log(aEtries.next().value);   //[0,1]位置0的值为1
console.log(aEtries.next().value);   //[1,2]位置1的值为2

key()    //返回包含索引的@@interator

let aKeys = number.keys();
console.log(aKeys.next());    //{value:0,done:false}
console.log(aKeys.next());    //{value:1,done:false}
console.log(aKeys.next());    //{value:0,done:falseval 

value()   //返回数组的值

let aValues = numbers.values();
console.log(aValues.next()); // {value: 1, done: false }
console.log(aValues.next()); // {value: 2, done: false }
console.log(aValues.next()); // {value: 3, done: false } 

(4)form()方法      //根据已有的数组创建新数组或者过滤数组

let numbers2 = Array.from(numbers);
//还可以传入一个用来过滤值的函数,例子如下:
let evens = Array.from(numbers, x => (x % 2 == 0));
//上面的代码会创建一个evens数组,其中只包含numbers数组中的偶数。

(5)Array.of方法   //根据传入的参数创建一个新数组

let numbers3 = Array.of(1);
let numbers4 = Array.of(1, 2, 3, 4, 5, 6);

//我们也可以用这个方法复制已有的数组
let numbersCopy = Array.of(...numbers4); 
//展开操作符(...)会把numbers4数组里的值都展开成参数。

 

以上是关于学习javascript数据结构和算法的主要内容,如果未能解决你的问题,请参考以下文章

学习Javascript的算法和数据结构--数组

学习JavaScript数据结构与算法 2/15

你可能不知道的JavaScript代码片段和技巧(下)

你可能不知道的JavaScript代码片段和技巧(上)

算法入门《数据结构与算法图解》+《我的第一本算法书》+《学习JavaScript数据结构与算法第3版》

常用Javascript代码片段集锦