Java算法-排序算法

简介:

冒泡排序

方法sort是基本的冒泡排序, sort1/sort2是冒泡排序的两种优化

package me.zx.algorithm.program.sort;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * 冒泡排序.
 * Created by zhangxin on 2017/12/27.
 *
 * @author zhangxin
 * @since 0.0.1
 */
public final class BubbleSort {

    private static final Logger LOGGER = LoggerFactory.getLogger(BubbleSort.class);

    /**
     * 基本的冒泡排序.
     * @param a 待排序数组
     */
    public static void sort(int[] a) {
        int temp = 0;
        for(int i = a.length - 1; i > 0; i--) {
            for(int j = 0; j < i; j++) {
                if(a[j + 1] < a[j]) {
                    temp = a[j];
                    a[j] = a[j + 1];
                    a[j + 1] = temp;
                }
            }
        }
    }

    /**
     * 优化的冒泡排序1.
     * 当某一趟遍历没有交换,就说明已经遍历好了,就不用再迭代了
     * @param a 待排序数组
     */
    public static void sort1(int[] a) {
        int temp = 0;
        boolean sorted = false;
        for(int i = a.length - 1; i > 0; i--) {
            sorted = false; //初始值设置为未排序
            for(int j = 0; j < i; j++) {
                if(a[j + 1] < a[j]) {
                    temp = a[j];
                    a[j] = a[j + 1];
                    a[j + 1] = temp;
                    sorted = true; //发生排序时重新设值
                }
            }
            if(!sorted){
                //当经过一次遍历没有发生一次排序, 或者上次排序位置与本次排序位置相同
                break;
            }
        }
    }
    /**
     * 优化的冒泡排序2.
     * 记录每次遍历数据之后交换次序的位置,显然这个位置之后的数据已经有序了不用再排序了。因此通过记录最后发生数据交换的位置就可以确定下次循环的范围了
     * @param a 待排序数组
     */
    public static void sort2(int[] a) {
        int temp = 0;
        int lastChangeLocation; //上次排序发生的位置
        int nowChangeLocation = a.length - 1; //本次排序发生的位置
        for(int i = a.length - 1; i > 0; i--) {
            lastChangeLocation = nowChangeLocation;
            for(int j = 0; j < i; j++) {
                if(a[j + 1] < a[j]) {
                    temp = a[j];
                    a[j] = a[j + 1];
                    a[j + 1] = temp;
                    nowChangeLocation = j; //发生排序时重新设值
                }
            }
            if(lastChangeLocation == nowChangeLocation){
                //当经过一次遍历没有发生一次排序, 或者上次排序位置与本次排序位置相同
                break;
            }
        }
    }



    public static void main(final String[] args){
//        int[] a = {0, 1, 2, 3, 4, 5, 6};
        int[] a = {6, 5, 4, 3, 2, 1, 0};
        LOGGER.info("原数组:{}", a);
        sort1(a);
        LOGGER.info("现数组:{}", a);
    }
}
目录
相关文章
|
1月前
|
算法 搜索推荐 Java
数据结构与算法(Java篇)笔记--希尔排序
数据结构与算法(Java篇)笔记--希尔排序
|
21天前
|
存储 算法 Java
Java数据结构与算法-java数据结构与算法(二)
Java数据结构与算法-java数据结构与算法
62 1
|
1月前
|
算法 Java
[Java·算法·中等] LeetCode15. 三数之和
[Java·算法·中等] LeetCode15. 三数之和
30 0
|
15天前
|
搜索推荐 Java
Java排序算法
Java排序算法
18 0
|
16天前
|
搜索推荐 Java
Java基础(快速排序算法)
Java基础(快速排序算法)
22 4
|
18天前
|
存储 算法 JavaScript
Java入门高频考查算法逻辑基础知识3-编程篇(超详细18题1.8万字参考编程实现)
解决这类问题时,建议采取下面的步骤: 理解数学原理:确保你懂得基本的数学公式和法则,这对于制定解决方案至关重要。 优化算法:了解时间复杂度和空间复杂度,并寻找优化的机会。特别注意避免不必要的重复计算。 代码实践:多编写实践代码,并确保你的代码是高效、清晰且稳健的。 错误检查和测试:要为你的代码编写测试案例,测试标准的、边缘情况以及异常输入。 进行复杂问题简化:面对复杂的问题时,先尝试简化问题,然后逐步分析和解决。 沟通和解释:在编写代码的时候清晰地沟通你的思路,不仅要写出正确的代码,还要能向面试官解释你的
32 0
|
21天前
|
XML 存储 算法
Java数据结构与算法-java数据结构与算法(五)
Java数据结构与算法-java数据结构与算法
47 0
|
29天前
|
算法 搜索推荐 Java
利用java编写的项目设备调配系统代码示例(内含5种设备调配的算法)
利用java编写的项目设备调配系统代码示例(内含5种设备调配的算法)
13 1
|
1月前
|
并行计算 算法 搜索推荐
|
1月前
|
算法 搜索推荐 Java
数据结构与算法(Java篇)笔记--快速排序
数据结构与算法(Java篇)笔记--快速排序