如何使用JavaScript交换变量

  介绍

这篇文章主要为大家展示了如何使用JavaScript交换变量,内容简而易懂,希望大家可以学习一下,学习完之后肯定会有收获的,下面让小编带大家一起来看看吧。

如何使用JavaScript交换变量”> <br/> </p> <p>许多算法需要交换2个变量。在编码面试中,可能会问您“如何在没有临时变量的情况下交换2个变量?”。我很高兴知道执行变量交换的多种方法。在本文中,您将了解大约4种交换方式(2种使用额外的内存,而2种不使用额外的内存)。</p> <h3> 1。解构赋值</h3> <p>解构赋值语法(ES2015的功能)使您可以将数组的项提取到变量中,例如,以下代码对数组进行解构:</p> <pre class=让;   让b;      [a, b]=[1, 2, 3];      一个;//=比;1   b;//=比;2

<代码> [a, b]=[1, 2, 3]> [1,2,3]> [1,2,3]> 1> ,第二项<代码> 2>

知道如何解构数组,可以很容易地使用它交换变量。让我们使用解构分配交换变量<代码> 和<代码> b>

让=1;
  让b=2;
  
  [a, b]=[b, a];
  
  一个;//=比;2
  b;//=比;1 

第一步,在解构的右侧,创建一个临时数组<代码> [b]> (2,1)>

然后发生临时数组的解构:<代码> [a, b]=(2, 1)> 分配了2 <代码> ,<代码> b> 1> 和<代码> b>

我喜欢这种解构方法,因为它简短而富有表现力:交换仅用一条语句执行。它适用于任何数据类型:数字,字符串,布尔值,对象。

对于大多数情况,我建议使用解构赋值来交换变量。

2。临时变量

使用临时变量交换变量是经典的。顾名思义,这种方法需要一个额外的临时变量。

让我们使用临时变量<代码>温度> 和<代码> b>

让=1;
  让b=2;
  让温度;
  
  temp=一个;
  a=b;
  b=temp;
  
  一个;//=比;2
  b;//=比;1 

3。加减法

您可以交换变量而无需使用额外的内存(例如临时数组或变量)。

以下示例使用加法<代码> +> - 算术运算符交换变量<代码> 和<代码> b>

让=1;
  让b=2;=a + b;
  b=a - b;
  一个=a - b;
  
  一个;//=比;2
  b;//=比;1 

最初,<代码> 为<代码> 1 ,<代码> b 为<代码> 2>

    <李> <代码>=a + b> 值<代码> 1 + 2> <李> <代码> b=a - b 为<代码> b> 1 + 2 - 2=1> 现在为<代码> 1> <李> <代码>=a - b 为<代码> 分配值<代码> 1 + 2 - 1=2 (<代码> 现在为<代码> 2>

最后,<代码> 为<代码> 2> 为<代码> 1> 和<代码> b>

尽管这种方法不使用临时变量,但有很大的局限性。

    <李>首先,您只能交换整数。 <李>其次,在第一步<代码>=a + b 进行加法时要注意数字溢出(总和必须小于<代码> Number.MAX_SAFE_INTEGER>

4。按位异或运算符

如果操作数不同,则XOR运算符的计算结果为真的。提醒一下,这是XOR真值表:

aba ^ b000110011101

在JavaScript中,按位异或运算符<代码> n1 ^ n2 对<代码> n1 和<代码> n2>

举例来说,这是<代码> 5 ^ 7> 2>

 1 0 1(5的二进制)
  1 1 1(7的二进制)
  -----
  0 1 0(5 ^ 7=2的二进制)

按位异或具有2个有趣的属性:

    <李> <代码> n ^ n=0 :对相同数字执行的按位异或为<代码> 0 。李李 <> <代码> n ^ 0=n :对一个数字执行按位异或,零是相同数字。

这些XOR属性可用于交换变量。让我们看看如何交换<代码> 和<代码> b>

让=1;
  让b=2;=^ b;
  b=^ b;=^ b;
  
  一个;//=比;2
  b;//=比;1 

如何使用JavaScript交换变量