【数据结构】实现冒泡排序算法(Java语言)

冒泡排序

  • 编程实现冒泡排序函数。public static void bubbleSort(int arr[])。其中arr存放待排序的数据,数组长度不大于1000
  • 函数接口定义:

/* 对长度为n的数组arr执行冒泡排序 */

public static void bubbleSort(int arr[]);

请实现bubbleSort函数,使排序后的数据从小到大排列。

c 复制代码
import java.util.Scanner;

public class Main {
    public static void main(String[] args){
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt();
        int[] arr = new int [n];
        for(int i = 0; i < n; i ++) {
            arr[i] = scanner.nextInt();
        }
        scanner.close();
        bubbleSort(arr);
        print(arr);         
    }
    public static void print(int[] arr) {
        for (int i : arr) {
            System.out.print(i + " ");
        }
        System.out.println("");
    }

	// ---------------------------------------------------------------------------
    // 【实现代码如下】
    // 排序函数
	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]) {
	                // 进行元素交换
	                int temp = arr[j];
	                arr[j] = arr[j + 1];
	                arr[j + 1] = temp;
	            }
	        }
	    }
	}
}
相关推荐
Aaa111114431 分钟前
四类地址 逻辑地址 线性地址 虚拟地址 物理地址
java
小则又沐风a2 分钟前
深入了解进程概念 第二章
java·linux·服务器·前端
程序猿进阶4 分钟前
OpenClaw Mac 安装教程
java·macos·ai·架构·agent·openclaw
变量未定义~5 分钟前
字符串哈希匹配字符串
数据结构·算法·哈希算法
周末也要写八哥9 分钟前
浅谈二叉树的深度优先搜索(DFS)算法
算法·深度优先
凯瑟琳.奥古斯特17 分钟前
信号分类与特性解析
java·开发语言·职场和发展
y = xⁿ20 分钟前
20天速通LeetCodeday17:一维动态规划
算法
JAVA面经实录91721 分钟前
JVM 性能监控 + 全链路分析实战 + 性能优化(完整版)
java·jvm
bnmoel25 分钟前
数据结构深度剖析栈与队列:结构、边界实现与进出操作全解析
c语言·数据结构·算法··队列
WL_Aurora26 分钟前
Python 算法基础篇之查找算法(一):顺序查找、二分查找与插值查找
开发语言·python·算法