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

运行结果:


总结

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

相关推荐
御风@户外17 分钟前
质数生成函数、质数判断备份
算法·acm
Cosmoshhhyyy18 分钟前
LeetCode:3083. 字符串及其反转中是否存在同一子字符串(哈希 Java)
java·leetcode·哈希算法
闻缺陷则喜何志丹30 分钟前
【C++动态规划】1105. 填充书架|2104
c++·算法·动态规划·力扣·高度·最小·书架
AI人H哥会Java32 分钟前
【Spring】基于XML的Spring容器配置——<bean>标签与属性解析
java·开发语言·spring boot·后端·架构
Dong雨41 分钟前
六大排序算法:插入排序、希尔排序、选择排序、冒泡排序、堆排序、快速排序
数据结构·算法·排序算法
开心工作室_kaic42 分钟前
springboot493基于java的美食信息推荐系统的设计与实现(论文+源码)_kaic
java·开发语言·美食
缺少动力的火车44 分钟前
Java前端基础—HTML
java·前端·html
达帮主1 小时前
7.C语言 宏(Macro) 宏定义,宏函数
linux·c语言·算法
loop lee1 小时前
Redis - Token & JWT 概念解析及双token实现分布式session存储实战
java·redis