Java冒泡排序

Java冒泡排序算法是一种简单的排序算法,它通过多次比较和交换相邻元素的方式将最大(或最小)的元素逐步移动到数组的末尾。以下是Java冒泡排序算法的实现步骤:

  1. 遍历数组,从第一个元素开始,依次比较相邻的两个元素。
  2. 如果前一个元素大于后一个元素,则交换它们的位置。
  3. 继续遍历数组,重复上述比较和交换的步骤,直到没有需要交换的元素为止。
  4. 重复执行上述步骤,每次遍历都将最大的元素移动到数组的末尾。
  5. 最终,数组将按照升序(或降序)排列。
java 复制代码
public class BubbleSort {
    public static void bubbleSort(int[] arr) {
        int n = arr.length;
        for (int i = 0; i < n - 1; i++) {
            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;
                }
            }
        }
    }

    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] + " ");
        }
    }
}
相关推荐
jimy19 小时前
C 语言的 static 关键字作用
c语言·开发语言·算法
0xDevNull9 小时前
Spring注解@Requestbody、@Requestparam、@PathVariable
java·后端·spring
七颗糖很甜9 小时前
基于IRI-2016模型计算电子密度、TEC、foF2等参数的技术原理与代码实现
大数据·python·算法
风筝在晴天搁浅9 小时前
LeetCode 143.重排链表
算法·leetcode·链表
budingxiaomoli9 小时前
环境和工程创建
java·spring·springcloud
碧海银沙音频科技研究院10 小时前
如何彻底关闭360壁纸
人工智能·深度学习·算法
sali-tec10 小时前
C# 基于OpenCv的视觉工作流-章57-人脸识别
图像处理·人工智能·opencv·算法·计算机视觉
计算机安禾10 小时前
【Linux从入门到精通】第43篇:I/O调度算法与磁盘性能优化
linux·算法·性能优化
这张生成的图像能检测吗10 小时前
(论文速读)FreDN:基于可学习频率分解的时间序列预测的频谱解纠缠
人工智能·深度学习·算法·机器学习·时序模型
梦想不只是梦与想10 小时前
java中多态的属性和方法
java·多态属性·多态方法