最最最简单的冒泡排序
每一趟把数值最大的弄到最后一个
最坏情况下进行n-1趟
原理以及思路
1.原理:比较两个相邻的元素,将值大的元素交换到右边
2.思路:依次比较相邻的两个数,将比较小的数放在前面,比较大的数放在后面。
(1)第一次比较:首先比较第一和第二个数,将小数放在前面,将大数放在后面。
(2)比较第2和第3个数,将小数 放在前面,大数放在后面。
…
(3)如此继续,知道比较到最后的两个数,将小数放在前面,大数放在后面,重复步骤,直至全部排序完成
(4)在上面一趟比较完成后,最后一个数一定是数组中最大的一个数,所以在比较第二趟的时候,最后一个数是不参加比较的。
(5)在第二趟比较完成后,倒数第二个数也一定是数组中倒数第二大数,所以在第三趟的比较中,最后两个数是不参与比较的。
(6)依次类推,每一趟比较次数减少依次
代码:
#include <bits/stdc++.h>
using namespace std;
int a[101],n;
void BubbleSort(int a[],int n)
{
int i,flag,temp;
temp=n-1,flag=1;
while((temp>0)&&flag==1)
{
flag=0;
for(i=1;i<=temp;i++)
{
if(a[i]>a[i+1])
{
flag=1;
swap(a[i],a[i+1]);
}
}
temp--;
}
}
int main()
{
int i;
cin>>n;
for(i=1;i<=n;i++)
{
cin>>a[i];
}
BubbleSort(a,n);
for(i=1;i<=n;i++)
{
cout<<a[i]<<" ";
}
return 0;
}
冒泡排序时间、空间复杂度
冒泡排序总的平均时间复杂度为:O(n2)
空间复杂度:O(1)