JavaScript数组反转教程

开发 前端
在工作面试和编码测试中,反转具有特定限制的数组是比较常见的挑战之一。本教程将向您展示在JavaScript中使用和不使用 reverse 方法来反转数组的五种方法,以及可以使用的代码段。

 在工作面试和编码测试中,反转具有特定限制的数组是比较常见的挑战之一。

[[381703]]

本教程将向您展示在JavaScript中使用和不使用 reverse 方法来反转数组的五种方法,以及可以使用的代码段。

如何使用Reverse方法反转JavaScript中的数组

当需要在JavaScript中反转数组时,可以使用 reverse 方法,该方法将最后一个元素放在第一位,而第一个元素放在最后:

 

  1. let numbers = [1, 2, 3, 4, 5]; 
  2. let reversedNumbers = numbers.reverse(); 
  3.  
  4. console.log(reversedNumbers); 
  5. // [5, 4, 3, 2, 1] 

但是请记住,reverse 方法也会修改原始数组:

  1. let numbers = [1, 2, 3, 4, 5]; 
  2. let reversedNumbers = numbers.reverse(); 
  3.  
  4. console.log(reversedNumbers); 
  5. // [5, 4, 3, 2, 1] 
  6.  
  7. console.log(numbers); 
  8. // [5, 4, 3, 2, 1] 

一些编码挑战可能希望您保留原始数组,因此让我们看一下如何在不更改原始数组的情况下反转数组。

如何使用Spread运算符反转JavaScript中的数组

你可以结合使用扩展运算符(Spread)和 reverse 方法来反转数组,而无需更改原始数组。

首先,通过用方括号 [] 括住spread语法,将spread运算符返回的元素放入新数组中:

 

  1. [...numbers] 

然后,你在数组上调用 reverse 方法。这样,将在新数组而不是原始数组上执行 reverse 方法:

 

  1. let numbers = [1, 2, 3, 4, 5]; 
  2. let reversedNumbers = [...numbers].reverse(); 
  3.  
  4. console.log(reversedNumbers); 
  5. // [5, 4, 3, 2, 1] 
  6.  
  7. console.log(numbers); 
  8. // [1, 2, 3, 4, 5] 

注意:spread 方法是ES6语法,当你需要支持较旧的浏览器或要使用ES5语法时,可以结合使用 slice 和 reverse 方法。让我们现在来看。

如何使用Slice和Reverse方法反转JavaScript中的数组

slice 方法用于将所选元素作为新数组返回,当你调用不带任何参数的方法时,它将返回一个与原始数组相同的新数组(从第一个元素到最后一个元素)。

接下来,你在新返回的数组上调用 reverse 方法,这就是为什么原始数组不反转的原因:

 

  1. let numbers = [1, 2, 3, 4, 5]; 
  2. let reversedNumbers = numbers.slice().reverse(); 
  3.  
  4. console.log(reversedNumbers); 
  5. // [5, 4, 3, 2, 1] 
  6.  
  7. console.log(numbers); 
  8. // [1, 2, 3, 4, 5] 

如何在没有Reverse方法的情况下在JavaScript中反转数组

有时面试会挑战你对数组进行逆向操作,而不采用 reverse 方法。没问题!你可以使用 for 循环和数组 push 方法的组合,就像下面的例子。

 

  1. let numbers = [1, 2, 3, 4, 5]; 
  2. let reversedNumbers = []; 
  3.  
  4. for(let i = numbers.length -1; i >= 0; i--) { 
  5.   reversedNumbers.push(numbers[i]); 
  6.  
  7. console.log(reversedNumbers); 

如何用JS编写自己的反转函数

最后,假设你的任务是编写自己的反转函数,该函数需要在不创建副本的情况下反转数组。乍一看,这似乎很复杂,但是不用担心,因为它实际上很简单。

在这里你需要做的是交换数组的第一个和最后一个元素,然后交换第二个和倒数第二个元素,依此类推,直到交换了所有元素。

 

 

 

 

让我们编写一个函数来做到这一点。

编写函数 customReverse,并使用 array.length - 1 作为变量,同时存储第一个索引为 0 和最后一个索引。

 

  1. function customReverse(originalArray) { 
  2.   let leftIndex = 0; 
  3.   let rightIndex = originalArray.length - 1; 

接下来,创建一个 while 循环,只要 leftIndex 小于 rightIndex,它就会运行。

在此循环内,交换 leftIndex 和 rightIndex 的值,你可以将值之一临时存储在临时变量中:

 

  1. while (leftIndex < rightIndex) { 
  2.   // 交换元素 
  3.   let temp = originalArray[leftIndex]; 
  4.   originalArray[leftIndex] = originalArray[rightIndex]; 
  5.   originalArray[rightIndex] = temp

最后,将 leftIndex 向上移动,将 rightIndex 向下移动,当 while 循环重复时,它将交换倒数第二个元素,依此类推:

 

  1. function customReverse(originalArray) { 
  2.  
  3.   let leftIndex = 0; 
  4.   let rightIndex = originalArray.length - 1; 
  5.  
  6.   while (leftIndex < rightIndex) { 
  7.  
  8.     // 用temp变量交换元素 
  9.     let temp = originalArray[leftIndex]; 
  10.     originalArray[leftIndex] = originalArray[rightIndex]; 
  11.     originalArray[rightIndex] = temp
  12.  
  13.     // 将索引移到中间 
  14.     leftIndex++; 
  15.     rightIndex--; 
  16.   } 

当没有其他要反转的元素时,循环将立即停止。对于奇数的数组 leftIndex 和 rightIndex 的值会相等,所以不用再交换。对于偶数的数组 leftIndex 将大于 rightIndex。

你可以测试该功能以查看其是否正常工作,如下所示:

 

  1. let myArray = [1, 2, 3, 4, 5]; 
  2.  
  3. customReverse(myArray); 
  4.  
  5. console.log(myArray); 
  6.  
  7. // output is [5, 4, 3, 2, 1] 

结束

恭喜你!你不仅学会了如何在JavaScript中反转数组,还学会了如何编写自己的反向函数。

责任编辑:华轩 来源: 前端全栈开发者
相关推荐

2022-04-20 11:14:55

Python列表数组

2010-07-20 13:12:11

Perl数组

2016-08-03 17:23:47

javascripthtml前端

2010-10-08 16:11:06

Javascript数

2019-07-17 14:06:45

JavaScript数组转换

2016-10-13 19:33:10

javascript数组indexOf

2014-01-22 09:46:42

JavaScript数组

2024-08-30 08:43:24

JavaScriptforEachfor循环

2022-09-26 09:01:15

语言数据JavaScript

2021-03-18 10:45:02

JavaScript数组运算符

2021-03-11 23:43:20

JavaScript数组开发

2020-08-21 17:40:15

JavaScript开发 技巧

2016-12-21 09:35:55

JavaScript原生数组函数

2017-04-06 14:10:08

JavaScript数组排序

2024-06-18 10:28:46

2024-07-17 11:35:31

JavaScript解构赋值

2024-09-10 15:34:18

JavaScript解构赋值

2021-07-26 05:20:47

JavaScript解构赋值数组解构

2021-09-22 23:17:09

Java开发数组

2016-12-27 10:19:42

JavaScriptindexOf
点赞
收藏

51CTO技术栈公众号