冒泡排序

Posted naloy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了冒泡排序相关的知识,希望对你有一定的参考价值。

原理

比较两个相邻的元素,将值大的元素交换至右端。

流程

数组 【3,6,4,2,11,10,5】

第一趟:首先比较3和6 ,3 < 6 ,继续 比较 6和4 ,6>4 ,6与4 交换 现在【3,4,6,2,11,10,5】,j继续比较 6和2 ,6>2 ,交换,【3,4,2,6,11,10,5】,继续比较..... 第一趟的最终结果为 【3,4,2,6,10,5,11

技术分享图片

一共7个元素,需要6趟排序(最后剩下第一个元素时已经是有序的了)所以总趟数为 N-1  ,每趟的比较次数为 N-第几趟

代码

package sequence;

import java.util.Arrays;

/**
 * 冒泡排序
 */
public class BubbSort {

    /**
     *
     * @param arr
     */
    public static void bubbleSort(int[] arr) {
       
        //控制趟数
        for (int i = arr.length - 1; i > 0; i--) {

            //控制比较次数
            for (int j = 0; j < i; j++) {
                if (arr[j] > arr[j+1]) {
                    swap(arr, j, j+1);
                }
            }

        }

        System.out.println(Arrays.toString(arr));
    }

    public static  void swap(int[] arr,int i,int j){
        arr[i] = arr[i] ^ arr[j];
        arr[j] = arr[i] ^ arr[j];
        arr[i] = arr[i] ^ arr[j];
    }

    public static void main(String[] args) {
        int[] arr = {3,6,4,2,11,10,5};
        bubbleSort(arr);
    }
}

 

以上是关于冒泡排序的主要内容,如果未能解决你的问题,请参考以下文章

java冒泡排序法代码

python代码实现鸡尾酒排序(双向冒泡排序)

冒泡排序python代码

视频+图文+动画详解冒泡排序

交换排序(冒泡排序快速排序的算法思想及代码实现)

C语言冒泡排序。