排序是许多比赛中需要应用到的题目,所谓排序,就是就一组具有相似性的数据按照一定的顺序进行排列,而冒泡排序是其中常见的一种,今天,小编就来粗略的讲解一下冒泡排序。
#include<iostream>
using namespace std;
int n,a[105];
int main(){
cin>>n;
for (int i=1;i<=n;i++) cin>>a[i];
for (int i=1;i<n;i++)
{
for (int j=i+1;j<=n;j++)
{
if (a[i]>a[j]) swap(a[i],a[j]);
}
}
for (int i=1;i<n;i++) cout<<a[i]<<",";
return 0;
}
首先,输入一组数据,利用嵌套的双层for循环,将两个数中较小的移到前面,较大的移到后面,以此来形成排序的效果,最后将数据输出。
冒泡排序重复地走访过要排序的元素列,依次比较两个相邻的元素,如果他们的顺序(如从大到小、首字母从A到Z)错误就把他们交换过来。走访元素的工作是重复地进行直到没有相邻元素需要交换,也就是说该元素列已经排序完成。
这个算法的名字由来是因为越大的元素会经由交换慢慢“浮”到数列的顶端,就如同碳酸饮料中二氧化碳的气泡最终会上浮到顶端一样,所以这种排序方法名为“冒泡排序”。