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");
        }
    }
}

运行结果:


总结

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

相关推荐
摇摆的含羞草13 分钟前
哈希(hash)算法使用特点及常见疑问解答
算法·哈希算法
FLGB16 分钟前
maven漏洞检测报告
java·maven
农夫山泉2号26 分钟前
【c++】——c++编译的so中函数有额外的字符
java·服务器·c++
wangan09436 分钟前
不带圆圈的二叉树
java·前端·javascript
小马哥编程1 小时前
【软考架构】滑动窗口限流算法的原理是什么?
java·开发语言·架构
仰泳的熊猫1 小时前
1077 Kuchiguse
数据结构·c++·算法·pat考试
饕餮争锋1 小时前
Spring AOP原理简析
java·spring
LYFlied1 小时前
【每日算法】LeetCode 19. 删除链表的倒数第 N 个结点
算法·leetcode·链表
okseekw1 小时前
Maven从入门到实战:核心概念+配置详解+避坑指南
java·后端
踏浪无痕1 小时前
计算机算钱为什么会算错?怎么解决?
后端·算法·面试