Java-冒泡排序

签名:但行好事,莫问前程。

文章目录


前言

记录一下经典算法:冒泡排序。


一、什么是冒泡排序

冒泡排序(Bubble Sort)是一种基本的排序算法。其原理是通过相邻元素之间的比较和交换来将最大或者最小值"冒泡"到数组的末尾。

它重复地走访过要排序的元素列,依次比较两个相邻的元素,如果顺序(如从大到小、首字母从Z到A)错误就把他们交换过来。走访元素的工作是重复地进行,直到没有相邻元素需要交换,也就是说该元素列已经排序完成。

这个算法的名字由来是因为越小的元素会经由交换慢慢"浮"到数列的顶端(升序或降序排列),就如同碳酸饮料中二氧化碳的气泡最终会上浮到顶端一样,故名"冒泡排序"。

二、手写冒泡排序

java 复制代码
public class ArrayTest {
    public static void main(String[] args) {
        int[] array = new int[]{9, 4, 2, 3, 1, 7, 8, 6, 5};
        // 冒泡排序
        for (int j = 0; j < array.length - 1; j++) {
            for (int i = 0; i < array.length - 1 - j; i++) {
                if (array[i] > array[i + 1]) {
                    // 交换两个元素的位置
                    int temp = array[i];
                    array[i] = array[i + 1];
                    array[i + 1] = temp;
                }
            }
        }
        // 打印结果
        for (int i = 0; i < array.length; i++) {
            System.out.print(array[i] + "\t");
        }
    }
}

运行结果:


总结

博客主要记录了手写冒泡排序,有啥错误或不足地方请指正,如果对你有所帮助,请一键三连。

相关推荐
老毛肚9 分钟前
手写mybatis
java·数据库·mybatis
两点王爷11 分钟前
Java基础面试题——【Java语言特性】
java·开发语言
choke23315 分钟前
[特殊字符] Python 文件与路径操作
java·前端·javascript
大江东去浪淘尽千古风流人物18 分钟前
【VLN】VLN(Vision-and-Language Navigation视觉语言导航)算法本质,范式难点及解决方向(1)
人工智能·python·算法
choke23320 分钟前
Python 基础语法精讲:数据类型、运算符与输入输出
java·linux·服务器
岁岁种桃花儿31 分钟前
CentOS7 彻底卸载所有JDK/JRE + 重新安装JDK8(实操完整版,解决kafka/jps报错)
java·开发语言·kafka
努力学算法的蒟蒻1 小时前
day79(2.7)——leetcode面试经典150
算法·leetcode·职场和发展
2401_841495641 小时前
【LeetCode刷题】二叉树的层序遍历
数据结构·python·算法·leetcode·二叉树··队列
AC赳赳老秦1 小时前
2026国产算力新周期:DeepSeek实战适配英伟达H200,引领大模型训练效率跃升
大数据·前端·人工智能·算法·tidb·memcache·deepseek
roman_日积跬步-终至千里1 小时前
【Java并发】Java 线程池实战:警惕使用CompletableFuture.supplyAsync
java·开发语言·网络