浅谈冒泡排序

手写一个冒泡排序的代码。

1.数组

javascript 复制代码
    let arr = [10, 2, 50, 23, 30, 56, 3];

2.排序的思路

里层的循环:

javascript 复制代码
  for (var i = 0; i <= arr.length; i++) {
        if (arr[i] < arr[i + 1]) {
          var temp = arr[i];
          arr[i] = arr[i + 1];
          arr[i + 1] = temp;
        }

用途:

javascript 复制代码
 [2, 10, 23, 30, 50, 3, 56]

这是第一次排序的结果:

arr[0]和arr[1] 比较如果arr[0]>arr[1]则两者相互交换位置。

10>2 -----------------2,10

arr[1]和arr[2]比较如果arr[1]>arr[2]两者交换位置

10<50-----------2 10 50

arr[2]和arr[3]两者交换位置

50>23------------2 10 23 50

arr[3]和arr[4]两者交换位置

50>30--------2 10 23 30 50

......

但是这不是我们想要的结果,我们想要的结果,是从小到大依次排序。

因此 要重复上面的操作

3.外层嵌套for循环

来重复里面排序的操作,最后i就可以得到一个,排列好的数组。

4.分析内层for循环

javascript 复制代码
      var temp = arr[i];
       arr[i] = arr[i + 1];
       arr[i + 1] = temp;

我们在数组中排序的时候,想要两者相互进行比较。

因为i从0开始,因此arr[i]代表数组中第一项。

arr[i+1],就能代表数组中的后一项。

刚开始我想的思路是:

javascript 复制代码
 arr[i] = arr[i+1]
 arr[i+1]=arr[i]

能够互换两者的位置,很显然这是异想天开了,这个后一位赋值给前一位之后,2赋值给10,第一位变成了2,这可以理解,后面继续执行代码,2赋值给第二位,这样的话不就重了吗?

因此:

javascript 复制代码
   var temp = arr[i];

将第一位的变量存起来,也就是把10存起来。

javascript 复制代码
 arr[i] = arr[i+1]

将后一位赋值给第一位,2,目前第二位还是2,

现在要做的就是把第一位赋值给后一位即可实现两者位置的调换。

此时存储起来的第一位变量就起到了作用:

javascript 复制代码
    arr[i + 1] = temp;

我们用图形来理解下:

假设1和2 要换位置

假设数组索引3号的数和数组索引4号的数换位置

总结:

通过,外界的一个临时变量先去存储值,然后来互换位置,达到冒泡的效果。

5.总结

1.通过外层的for循环重复内层的for循环来进行重复的排序。

2.通过声明一个临时的变量,来交换两个数之间的位置。

相关推荐
穿条秋裤到处跑3 小时前
每日一道leetcode(2026.03.30):判断通过操作能否让字符串相等 II
算法·leetcode
Q741_1473 小时前
每日一题 力扣 2840. 判断通过操作能否让字符串相等 II 力扣 2839. 判断通过操作能否让字符串相等 I 找规律 字符串 C++ 题解
c++·算法·leetcode·力扣·数组·找规律
xu_wenming3 小时前
在 TinyML 场景下,如何将模型从 FP32 量化为 INT8?
arm开发·算法·iot
csdn_aspnet3 小时前
C++ 求n边凸多边形的对角线数量(Find number of diagonals in n sided convex polygon)
开发语言·c++·算法
深邃-3 小时前
字符函数和字符串函数(1)
c语言·开发语言·数据结构·c++·算法·html5
我真不是小鱼3 小时前
cpp刷题打卡记录24——路径总和 & 路径总和II
数据结构·c++·算法·leetcode
菜鸟小九3 小时前
JVM垃圾回收
java·jvm·算法
nianniannnn3 小时前
力扣 347. 前 K 个高频元素
c++·算法·leetcode
x_xbx3 小时前
LeetCode:217. 存在重复元素
数据结构·leetcode·哈希算法
漫随流水3 小时前
c++编程:求阶乘和
数据结构·c++·算法