0

0

Java中冒泡排序怎么实现 详解经典排序算法的Java代码

下次还敢

下次还敢

发布时间:2025-06-29 21:35:01

|

269人浏览过

|

来源于php中文网

原创

冒泡排序的优化空间主要有两种:1. 使用swapped标志位减少不必要的遍历;2. 记录每趟最后一次交换的位置,减少内层循环次数。此外,常见的经典排序算法包括选择排序、插入排序、快速排序和归并排序,它们各有优劣,适用于不同场景。选择排序需综合考虑数据规模、数据特点、内存限制及稳定性等因素。

Java中冒泡排序怎么实现 详解经典排序算法的Java代码

冒泡排序,简单来说,就是像水底的气泡一样,轻的先冒出来。在Java里实现它,就是重复比较相邻的元素,如果顺序不对就交换,直到整个数组排好序。

Java中冒泡排序怎么实现 详解经典排序算法的Java代码

解决方案

Java中冒泡排序怎么实现 详解经典排序算法的Java代码
public class BubbleSort {

    public static void bubbleSort(int[] arr) {
        int n = arr.length;
        boolean swapped; // 优化:如果一趟下来没有发生交换,说明已经有序

        for (int i = 0; i < n - 1; i++) {
            swapped = false;
            for (int j = 0; j < n - i - 1; j++) {
                if (arr[j] > arr[j + 1]) {
                    // 交换 arr[j] 和 arr[j+1]
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                    swapped = true;
                }
            }

            // 如果没有发生交换,说明数组已经有序
            if (!swapped) {
                break;
            }
        }
    }

    // 测试
    public static void main(String[] args) {
        int[] arr = {64, 34, 25, 12, 22, 11, 90};
        bubbleSort(arr);
        System.out.println("排序后的数组:");
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
    }
}

这段代码的核心在于两个嵌套的循环。外层循环控制排序的趟数,内层循环负责比较和交换。swapped变量是个小优化,如果某一趟下来没有发生任何交换,说明数组已经是有序的,就可以直接结束排序了。

立即学习Java免费学习笔记(深入)”;

冒泡排序的时间复杂度是O(n^2),在数据量大的时候效率不高。但是,它的实现非常简单,易于理解,所以在一些对性能要求不高的场景下,或者作为教学示例,还是很有用的。

Java中冒泡排序怎么实现 详解经典排序算法的Java代码

冒泡排序的优化空间有哪些?

除了上面提到的swapped标志位优化,还有一些其他的优化思路。比如,可以记录下每一趟排序中最后一次发生交换的位置,下一趟排序的时候,只需要比较到这个位置就可以了。

GradPen论文
GradPen论文

GradPen是一款AI论文智能助手,深度融合DeepSeek,为您的学术之路保驾护航,祝您写作顺利!

下载
public static void optimizedBubbleSort(int[] arr) {
    int n = arr.length;
    int lastSwap = n - 1; // 记录最后一次交换的位置

    while (lastSwap > 0) {
        int currentSwap = 0; // 本趟排序最后一次交换的位置
        for (int j = 0; j < lastSwap; j++) {
            if (arr[j] > arr[j + 1]) {
                // 交换 arr[j] 和 arr[j+1]
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
                currentSwap = j; // 记录本次交换的位置
            }
        }
        lastSwap = currentSwap; // 更新最后一次交换的位置
    }
}

这个优化主要减少了内层循环的次数,尤其是在数组部分有序的情况下,效果会比较明显。但是,最坏情况下,时间复杂度仍然是O(n^2)。

除了冒泡排序,还有哪些经典的排序算法值得学习?

排序算法有很多,除了冒泡排序,还有选择排序、插入排序、快速排序、归并排序等等。

  • 选择排序:每次从未排序的部分选择最小的元素,放到已排序部分的末尾。
  • 插入排序:将未排序的元素插入到已排序序列的合适位置。
  • 快速排序:选择一个基准元素,将数组分成两部分,一部分小于基准,一部分大于基准,然后递归地对这两部分进行排序。
  • 归并排序:将数组递归地分成两半,分别排序,然后将排序好的两部分合并起来。

这些算法各有优缺点,适用于不同的场景。快速排序和归并排序的时间复杂度是O(n log n),在大多数情况下效率更高。但是,它们的实现相对复杂一些。选择排序和插入排序虽然简单,但是效率较低。

如何选择合适的排序算法?

选择排序算法需要考虑多个因素,包括:

  • 数据规模:数据量越大,越应该选择时间复杂度低的算法,比如快速排序或归并排序。
  • 数据特点:如果数据基本有序,插入排序可能比快速排序更快。
  • 内存限制:归并排序需要额外的内存空间,如果内存有限制,可能需要选择原地排序的算法,比如堆排序。
  • 稳定性:如果需要保持相等元素的相对顺序,需要选择稳定的排序算法,比如归并排序和插入排序。

没有一种排序算法是万能的,需要根据具体的应用场景进行选择。很多编程语言的内置排序函数,比如Java的Arrays.sort(),通常会根据数据规模和特点自动选择合适的排序算法。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

391

2023.09.04

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

395

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

575

2023.08.10

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

407

2023.08.14

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

109

2026.01.26

edge浏览器怎样设置主页 edge浏览器自定义设置教程
edge浏览器怎样设置主页 edge浏览器自定义设置教程

在Edge浏览器中设置主页,请依次点击右上角“...”图标 > 设置 > 开始、主页和新建标签页。在“Microsoft Edge 启动时”选择“打开以下页面”,点击“添加新页面”并输入网址。若要使用主页按钮,需在“外观”设置中开启“显示主页按钮”并设定网址。

16

2026.01.26

苹果官方查询网站 苹果手机正品激活查询入口
苹果官方查询网站 苹果手机正品激活查询入口

苹果官方查询网站主要通过 checkcoverage.apple.com/cn/zh/ 进行,可用于查询序列号(SN)对应的保修状态、激活日期及技术支持服务。此外,查找丢失设备请使用 iCloud.com/find,购买信息与物流可访问 Apple (中国大陆) 订单状态页面。

131

2026.01.26

npd人格什么意思 npd人格有什么特征
npd人格什么意思 npd人格有什么特征

NPD(Narcissistic Personality Disorder)即自恋型人格障碍,是一种心理健康问题,特点是极度夸大自我重要性、需要过度赞美与关注,同时极度缺乏共情能力,背后常掩藏着低自尊和不安全感,影响人际关系、工作和生活,通常在青少年时期开始显现,需由专业人士诊断。

7

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.9万人学习

C# 教程
C# 教程

共94课时 | 7.7万人学习

Java 教程
Java 教程

共578课时 | 52.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号