## 冒泡排序 - 冒泡排序(Bubble Sort)是一种简单的排序算法。它重复 地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。 ![](https://img-blog.csdnimg.cn/img_convert/020ed41347b2d78bde3cfa328867ccdb.gif) - 排序思路: + 假设按照升序排序 + 1.从第0个元素开始, 每次都用相邻两个元素进行比较 + 2.一旦发现后面一个元素小于前面一个元素就交换位置 + 3.经过一轮比较之后最后一个元素就是最大值 + 4.排除最后一个元素, 以此类推, 每次比较完成之后最大值都会出现再被比较所有元素的最后 + 直到当前元素没有可比较的元素, 排序完成 - 代码实现: ```c // 冒泡排序 void bubbleSort(int numbers[], int length) { for (int i = 0; i < length; i++) { // -1防止`角标越界`: 访问到了不属于自己的索引 for (int j = 0; j < length - i - 1; j++) { // 1.用当前元素和相邻元素比较 if (numbers[j] < numbers[j + 1]) { // 2.一旦发现小于就交换位置 swapEle(numbers, j, j + 1); } } } } // 交换两个元素的值, i/j需要交换的索引 void swapEle(int array[], int i, int j) { int temp = array[i]; array[i] = array[j]; array[j] = temp; } ``` ## 最后,如果有任何疑问,请加微信 **leader_fengy** 拉你进学习交流群。 开源不易,码字不易,如果觉得有价值,欢迎分享支持。