排序算法 —— 冒泡排序
- 概念
冒泡排序是一种计算机科学领域的较简单的排序算法。
它重复地走访过要排序的元素列,依次比较两个相邻的元素,如果顺序错误就把他们交换过来。走访元素的工作是重复地进行直到没有相邻元素需要交换,也就是说该元素列已经排序完成。
这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端(升序或降序排列),就如同碳酸饮料中二氧化碳的气泡最终会上浮到顶端一样,故名“冒泡排序”。
- 代码
int arr[5] = {3, 2, 1, 4, 5};
int arrLen = 5;
int temp;
for (int i = 0; i < arrLen - 1; i++){
for (int j = arrLen - 1; j > i; j--){
if (arr[j] < arr[j - 1]){
temp = arr[j];
arr[j] = arr[j - 1];
arr[j - 1] = temp;
}
}
}
- 图解
- 原数据
- 第一趟循环
- 第二趟循环
- 第三趟循环
- 第四趟循环
- 不难发现当第二趟循环结束后,数据已经有序。但循环仍在进行,因此我们可以对代码进行优化。
- 优化代码
int arr[5] = {3, 2, 1, 4, 5};
int arrLen = 5;
int temp;
int i = 0;
bool flag = true;
while (flag && i < arrLen - 1)
flag = false;
for (int j = arrLen - 1; j > i; j--){
if (arr[j] < arr[j - 1]){
temp = arr[j];
arr[j] = arr[j - 1];
arr[j - 1] = temp;
flag = true;
}
}
i++;
}