排序系列之冒泡排序

简介: 排序系列之冒泡排序

冒泡排序


冒泡排序(Bubble Sort),是一种计算机科学领域的较简单的排序算法

它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。

这个算法的名字由来是因为越大的元素会经由交换慢慢“浮”到数列的顶端,故名。

 

算法原理


冒泡排序算法的运作如下:(从后往前)

  1. 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
  2. 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
  3. 针对所有的元素重复以上的步骤,除了最后一个。
  4. 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较

 5. 时间复杂度

若文件的初始状态是正序的,一趟扫描即可完成排序。所需的关键字比较次数

 和记录移动次数  均达到最小值:  


算法稳定性

冒泡排序就是把小的元素往前调或者把大的元素往后调。比较是相邻的两个元素比较,交换也发生在这两个元素之间。所以,如果两个元素相等,我想你是不会再无聊地把他们俩交换一下的;如果两个相等的元素没有相邻,那么即使通过前面的两两交换把两个相邻起来,这时候也不会交换,所以相同元素的前后顺序并没有改变,所以冒泡排序是一种稳定排序算法。

java实现:

 package com.led.sort;
  import java.util.Arrays;
  /**
   * Bubble Sort: Digital from small to large
   * 
   * @author Lin_Hero
   * 
  */
 public class Bubble001 {
     public static int[] BubbleSort(int[] a) {
         int temp;
         for (int i = 0; i < a.length; i++) {
             for (int j = i + 1; j < a.length; j++) {
                 if (a[i] > a[j]) {
                     temp = a[i];
                     a[i] = a[j];
                     a[j] = temp;
                 }
             }
         }
         return a;
     }
     public static void main(String[] args) {
         int[] array = { 1, -6, -99, 67, 45, 8, 0, -90 };
         System.out.println("Before bubble sort:");
         System.out.println(Arrays.toString(array));
         Bubble001.BubbleSort(array); // 静态方法的调用:类名.方法名
         System.out.println("After bubble sort:");
         System.out.println(Arrays.toString(array));
     }
 }

Before bubble sort:


[1, -6, -99, 67, 45, 8, 0, -90]


After bubble sort:


[-99, -90, -6, 0, 1, 8, 45, 67]

相关文章
|
8月前
|
搜索推荐 算法 Shell
排序——插入排序
排序——插入排序
55 0
|
8月前
|
算法 搜索推荐
排序——选择排序
排序——选择排序
80 0
|
存储 搜索推荐 测试技术
排序篇(一)----插入排序
排序篇(一)----插入排序
58 0
LetCode第912题 排序数组之冒泡排序
依次比较相邻的两du个数,将小数放在前面zhi,大数放在后面。即首先比较第dao1个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。重复以上过程,仍从第一对数开始比较(因为可能由于第2个数和第3个数的交换,使得第1个数不再大于第2个数),将小数放前,大数放后,一直比较到最小数前的一对相邻数,将小数放前,大数放后,第二趟结束,在倒数第二个数中得到一个新的最小数。如此下去,直至最终完成排序。
65 0
LetCode第912题 排序数组之冒泡排序
|
算法 搜索推荐 索引
排序篇(二)----选择排序
排序篇(二)----选择排序
41 0
|
算法 搜索推荐
排序——冒泡排序
这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端(升序或降序排列),就如同碳酸饮料中二氧化碳的气泡最终会上浮到顶端一样,故名“冒泡排序”。
|
存储 搜索推荐 测试技术
排序(1)之插入排序
从今天小编就开始给大家介绍排序的内容,对于排序内容我们一共分,插入,选择,交换,归并这几个大类,那么今天小编给大家带来的就是插入排序
110 0
|
搜索推荐
排序(2)之选择排序
继插入排序后,今天小编就给大家另一个模块,选择排序的学习,那么话不多说,我们直接进入正题。
124 0
|
索引
掌握常见的几种排序-选择排序
选择排序是一种简单的排序,时间复杂度是O(n^2),在未排序的数组中找到最小的那个数字,然后将其放到起始位置,从剩下未排序的数据中继续寻找最小的元素,将其放到已排序的末尾,以此类推,直到所有元素排序结束为止。
128 0
掌握常见的几种排序-选择排序
|
算法 搜索推荐
排序——归并排序和计数排序
介绍归并排序和计数排序
124 0
排序——归并排序和计数排序