排序算法(一):冒泡排序(Bubble Sort)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_34288630/article/details/79282237

冒泡排序原理
冒泡排序思路就是交换排序,通过相邻数据的交换来达到排序的目的
冒泡排序思路
1、对数组中的各数据,一次比较相邻的两个元素的大小。
2、如果前面的数据大于后面的数据,就交换两个数据,经过第一轮的多次比较排序后,便可以将最小的数据排好。
3、再用同样的的方法把剩下的数据逐个进行排序,最后便可以按照从小到大顺序排好各组数据。
举例说明
初始数据:118、101、105、127、112
第一趟排序:
101、118、105、112、127
第二趟排序:
101、105、118、112、127
第三趟排序:
101、105、112、118、127
第四次排序:
101、105、112、118、127
冒泡算法在对n个数据进行排序时,无论原数据有无顺序,都需要进行n-1步的中间排序,这种排序方法直观简单,但是缺点是执行步骤稍长,效率不高。

由上面的可以总结:N个数字要排序完成,总共进行N-1趟排序,每趟排序次数为(N-i)次,所以可以用双重循环语句,外层控制循环多少趟,内层控制循环每趟的次数:

for(int i=1;i<arr.length;i++){

    for(int j=1;j<arr.length-i;j++){

    //交换位置
    }
} 

冒泡排序的优点:每进行一趟排序,就会少比较一次,因为每进行一趟排序都会找出一个较小值

用时间复杂度来说:

  1.如果我们的数据正序,只需要走一趟即可完成排序。所需的比较次数C和记录移动次数M均达到最小值,即:Cmin=n-1;Mmin=0;所以,冒泡排序最好的时间复杂度为O(n)。

  2.如果很不幸我们的数据是反序的,则需要进行n-1趟排序。每趟排序要进行n-i次比较(1≤i≤n-1),且每次比较都必须移动记录三次来达到交换记录位置。在这种情况下,比较和移动次数均达到最大值:冒泡排序的最坏时间复杂度为:O(n2) 。

综上所述:冒泡排序总的平均时间复杂度为:O(n2) 。

/*
 * 冒泡排序
 */
public class BubbleSort {
  public static void main(String[] args) {
    int[] arr={6,3,8,2,9,1};
    System.out.println("排序前数组为:");
    for(int num:arr){
      System.out.print(num+" ");
    }
    for(int i=0;i<arr.length-1;i++){//外层循环控制排序趟数
      for(int j=0;j<arr.length-1-i;j++){//内层循环控制每一趟排序多少次
        if(arr[j]<arr[j+1]){
          int temp=arr[j];
          arr[j]=arr[j+1];
          arr[j+1]=temp;
        }
      }
    } 
    System.out.println();
    System.out.println("排序后的数组为:");
     for(int num:arr){
       System.out.print(num+" ");
     } 
  }
 }
阅读更多
换一批

没有更多推荐了,返回首页