双向起泡排序实现如下:
#include<iostream>
using namespace std;
// 交换两个数
void swap(int &i, int &j)
{
int t = i;
i = j;
j = t;
}
// 打印数组
void show(int a[], int n)
{
for(int i = 0; i < n; i++)
{
cout << a[i] << " ";
}
cout << endl;
}
// 双向起泡排序
void bubblesort(int a[], int n)
{
int low = 0, high = n-1;
bool flag = true;
while(low < high && flag)
{
flag = false;
show(a, 10);
int i = low;
while(i < high)
{
if(a[i] > a[i + 1])
{
swap(a[i], a[i + 1]);
flag = true;
}
i++;
}
high--;
int j = high;
while(j > low)
{
if(a[j] < a[j-1])
{
swap(a[j-1], a[j]);
flag = true;
}
j--;
}
low++;
}
}
int main(){
int a[] = {10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
int n = 10;
// 输出初始状态
// show(a, n);
// 双向冒泡排序
bubblesort(a, n);
// 排序后输出
cout << "after sort" << endl;
show(a, n);
}
代码中示例的输出为:
10 9 8 7 6 5 4 3 2 1
1 9 8 7 6 5 4 3 2 10
1 2 8 7 6 5 4 3 9 10
1 2 3 7 6 5 4 8 9 10
1 2 3 4 6 5 7 8 9 10
after sort
1 2 3 4 5 6 7 8 9 10