登录
首页 >  文章 >  前端

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

时间:2024-11-08 16:22:04 403浏览 收藏

大家好,我们又见面了啊~本文《冒泡排序中打印数组的变化:为什么交换元素后,原始数组也发生了改变? 》的内容中将会涉及到等等。如果你正在学习文章相关知识,欢迎关注我,以后会给大家带来更多文章相关文章,希望我们能一起进步!下面就开始本文的正式内容~

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

打印数组引发的困惑

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

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]];

以上就是《冒泡排序中打印数组的变化:为什么交换元素后,原始数组也发生了改变? 》的详细内容,更多关于的资料请关注golang学习网公众号!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>