冒泡排序
是一种简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。
算法规则:
由于算法每次都将一个最大的元素往上冒,我们可以将待排序集合(0...n)看成两部分,一部分为(k..n)的待排序unsorted集合,另一部分为(0...k)的已排序sorted集合,每一次都在unsorted集合从前往后遍历,选出一个数,如果这个数比其后面的数大,则进行交换。完成一轮之后,就肯定能将这一轮unsorted集合中最大的数移动到集合的最后,并且将这个数从unsorted中删除,移入sorted中。
代码实现(Java版本)
public void sort(int[] array) {
for (int j = 0; j < array.length; j++) {
for (int i = 0; i < array.length - 1; i++) {
if (array[i] < array[i + 1]) {
continue;
} else {
int temp = array[i];
array[i] = array[i + 1];
array[i + 1] = temp;
}
}
}
}