冒泡排序的思想:比较相邻的两个元素的大小,如果前者比后者大,就交换这两个元素。
假设有n个元素的话,就要比较n-1趟,第一趟比较得到最大的元素,将该元素放在数组下标为【n-1】的位置上,第二趟比较则就不用和最后一个元素比较了,比第一趟能少比较一次,将第二大的元素放在下标为【n-2】的位置上,以此类推。
假设有如下数组arr[]:
![](https://img.haomeiwen.com/i7375573/85c87c4b79e6e62e.png)
第一趟排序:
![](https://img.haomeiwen.com/i7375573/ad2063582fe84ee5.png)
判断第i个元素和第i+1个元素的大小,如果arr[i]>arr[i+1],则交换这两个元素,判断一次i++一次;直到i=size-1;
![](https://img.haomeiwen.com/i7375573/d90e55b0e0c64e34.png)
第二趟到第n-1趟与之类似;代码实现如下:
未优化:
![](https://img.haomeiwen.com/i7375573/d6e8c8ebdc1706a5.png)
优化1:如果其中几趟没有交换元素则可以减少判断
![](https://img.haomeiwen.com/i7375573/fd99e4338948a1a7.png)
优化2:如果一个数组后面很多元素已经有序,只是前面元素无序,则可以只排序前面无序的元素
![](https://img.haomeiwen.com/i7375573/5530b42d028e135c.png)
网友评论