首页 > 编程语言 > 详细

冒泡排序

时间:2018-11-02 01:15:50      阅读:217      评论:0      收藏:0      [点我收藏+]

原理

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

流程

数组 【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);
    }
}

 

冒泡排序

原文:https://www.cnblogs.com/naloy/p/9893343.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!