博客
关于我
冒泡排序及其优化方案
阅读量:454 次
发布时间:2019-03-06

本文共 2525 字,大约阅读时间需要 8 分钟。

冒泡排序及其优化(以升序为例)

排序流程

冒泡排序是一种简单有效的排序算法,通过反复交换相邻元素的位置,使数组逐渐变得有序。具体流程如下:

  • 从头开始比较相邻的两个元素:如果后面一个比前面一个小,就交换它们的位置。这样执行一轮,最后一个元素就是最大值。
  • 忽略之前找到的最大元素:重复执行步骤1,直到整个数组有序。

  • 代码实现

    以下是冒泡排序的原始代码实现:

    package bubblesort;public class sort1 {    public static void main(String[] args) {        int[] arr = {1, 4, 5, 2, 6, 8, 4, 5};        int end = arr.length - 1;        for (; 0 <= end; end--) {            for (int start = 0; start < end; start++) {                if (arr[start] > arr[start + 1]) {                    int temp = arr[start];                    arr[start] = arr[start + 1];                    arr[start + 1] = temp;                }            }        }        for (int i = 0; i < arr.length; i++) {            System.out.println(arr[i]);        }    }}

    优化方案一

    优化思路:如果在排序到一半时数组已经有序,后续的排序操作是浪费资源。我们可以通过在每次排序开始前判断数组是否已经有序,提前终止排序过程。

    实现方案:在每次排序开始前,检查数组中是否存在相邻元素逆序。如果没有,说明数组已经有序,直接退出循环。

    package bubblesort;public class sort1 {    public static void main(String[] args) {        int[] arr = {1, 4, 5, 2, 6, 8, 4, 5};        int end = arr.length - 1;        for (; 0 <= end; end--) {            boolean isSorted = true;            for (int start = 0; start < end; start++) {                if (arr[start] > arr[start + 1]) {                    int temp = arr[start];                    arr[start] = arr[start + 1];                    arr[start + 1] = temp;                    isSorted = false;                }            }            if (isSorted) {                break;            }        }        for (int i = 0; i < arr.length; i++) {            System.out.println(arr[i]);        }    }}

    优化方案二

    优化思路:在排序过程中,数组的后半部分可能已经局部有序。我们可以记录最后一次交换的位置,并将后续排序范围缩减到这一位置之前,从而减少不必要的比较和交换。

    实现方案:在每次循环中记录最后一次交换的位置。如果后续没有交换发生,说明前面已经有序,可以提前终止排序。

    package bubblesort;public class sort3 {    public static void main(String[] args) {        int[] arr = {1, 4, 5, 2, 6, 8, 4, 5};        int end = arr.length - 1;        for (; 0 <= end; end--) {            int sortIndex = 1;            for (int start = 0; start < end; start++) {                if (arr[start] > arr[start + 1]) {                    int temp = arr[start];                    arr[start] = arr[start + 1];                    arr[start + 1] = temp;                    sortIndex = start;                }            }            end = sortIndex;        }        for (int i = 0; i < arr.length; i++) {            System.out.println(arr[i]);        }    }}

    算法的稳定性

    冒泡排序是一种稳定的排序算法。稳定性意味着:如果两个元素相等,它们在排序后的顺序与原始顺序相同。这种特性在处理多个相同元素时尤为重要。


    以上就是冒泡排序算法及其优化方案,希望对您有所帮助!如有疑问,欢迎在评论区留言。我将致力于提供高质量的技术内容,感谢您的关注与支持!

    转载地址:http://nckfz.baihongyu.com/

    你可能感兴趣的文章
    nnU-Net 终极指南
    查看>>
    No 'Access-Control-Allow-Origin' header is present on the requested resource.
    查看>>
    NO 157 去掉禅道访问地址中的zentao
    查看>>
    no available service ‘default‘ found, please make sure registry config corre seata
    查看>>
    No compiler is provided in this environment. Perhaps you are running on a JRE rather than a JDK?
    查看>>
    no connection could be made because the target machine actively refused it.问题解决
    查看>>
    No Datastore Session bound to thread, and configuration does not allow creation of non-transactional
    查看>>
    No fallbackFactory instance of type class com.ruoyi---SpringCloud Alibaba_若依微服务框架改造---工作笔记005
    查看>>
    No Feign Client for loadBalancing defined. Did you forget to include spring-cloud-starter-loadbalanc
    查看>>
    No mapping found for HTTP request with URI [/...] in DispatcherServlet with name ...的解决方法
    查看>>
    No mapping found for HTTP request with URI [/logout.do] in DispatcherServlet with name 'springmvc'
    查看>>
    No module named 'crispy_forms'等使用pycharm开发
    查看>>
    No module named cv2
    查看>>
    No module named tensorboard.main在安装tensorboardX的时候遇到的问题
    查看>>
    No module named ‘MySQLdb‘错误解决No module named ‘MySQLdb‘错误解决
    查看>>
    No new migrations found. Your system is up-to-date.
    查看>>
    No qualifying bean of type XXX found for dependency XXX.
    查看>>
    No qualifying bean of type ‘com.netflix.discovery.AbstractDiscoveryClientOptionalArgs<?>‘ available
    查看>>
    No resource identifier found for attribute 'srcCompat' in package的解决办法
    查看>>
    no session found for current thread
    查看>>