
通过这种方法,我们可以得到以下排序过程:

经过分析,我们可以得到元素个数、排序轮数和对比次数之间的数学关系。这样就找到了代码的逻辑关系:
/*
冒泡排序
*/
#include <iostream>
#include <time.h>
using namespace std;
typedef int ElemType;
// 交换顺序
void swap(ElemType &a, ElemType &b) {
ElemType temp = a;
a = b;
b = temp;
}
// 冒泡排序
void BubbleSort(ElemType arr[], int len) {
for (int i = 0; i < len - 1; i++) {
for (int j = len - 1; j > i; j--) {
if (arr[j - 1] > arr[j]) {
swap(arr[j - 1], arr[j]);
}
}
}
}
// 优化方法
void BubbleSort1(ElemType arr[], int len) {
int flag;
for (int i = 0; i < len - 1; i++) {
flag = 0;
for (int j = len - 1; j > i; j--) {
if (arr[j - 1] > arr[j]) {
swap(arr[j - 1], arr[j]);
flag = 1;
}
}
if (flag = 0) { // 这一趟没有交换,意味着剩下的已经有序
break;
}
}
}
int main() {
int len = 10;
ElemType arr[len] = {};
srand(time(NULL));
for (int i = 0; i < len; i++) {
arr[i] = rand() % 100; // 随机生成
cout << arr[i] << ' ';
}
cout << endl;
BubbleSort1(arr, len);
for (int i = 0; i < len; i++) {
cout << arr[i] << ' ';
}
}