冒泡排序中打印数组的变化:为什么交换元素后,原始数组也发生了改变?

冒泡排序中打印数组的变化:为什么交换元素后,原始数组也发生了改变?

打印数组引发的困惑

在学习冒泡排序时,对于打印数组的操作产生了一个令人困惑的现象。在元素交换位置前打印的数组结构与交换后打印的数组结构不同。以下代码示例演示了该问题:

function bubbleSort(array) {
  for (let i = 0; i < array.length - 1; i++) {
    for (let j = i + 1; j < array.length; j++) {
      if (array[j] < array[i]) {
        const oldArr = JSON.parse(JSON.stringify(array));
        console.log(oldArr);
        [array[i], array[j]] = [array[j], array[i]];
      }
    }
  }
}

var arr = [1, 3, 6, 3, 23, 1, 34];
bubbleSort(arr);

在元素交换位置前打印的数组结构:

[1, 3, 6, 3, 23, 1, 34]
[1, 1, 6, 3, 23, 3, 34]
[1, 1, 3, 6, 23, 3, 34]
[1, 1, 3, 3, 23, 6, 34]

在元素交换位置后打印的数组结构:

[1, 3]
[3, 6]
[1, 6]
[1, 3]
[1, 23]

困惑的关键在于,JSON.parse(JSON.stringify()) 复制了原始数组,并没有解除原始数组和复制数组之间的指针链接。因此,在元素交换位置后,原始数组也发生了变化,导致打印的数组结构也不同。

解决该问题的正确方法是使用解构赋值来交换数组元素,例如:

[array[i], array[j]] = [array[j], array[i]];

以上就是冒泡排序中打印数组的变化:为什么交换元素后,原始数组也发生了改变?的详细内容,更多请关注其它相关文章!