【数据结构】实现冒泡排序算法(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;
	            }
	        }
	    }
	}
}
相关推荐
喧星Aries几秒前
进程调度的时机,切换与过程方式(操作系统OS)
java·服务器·前端·操作系统·进程调度
JouJz1 分钟前
Spring事务管理深度解析:原理、实践与陷阱
java·spring
此乃大忽悠5 分钟前
身份认证缺陷
java·数据库·webgoat·身份认证缺陷
Honyee14 分钟前
java使用UCanAccess操作Access
java·后端
秋千码途15 分钟前
小架构step系列10:日志热更新
java·linux·微服务
她说人狗殊途18 分钟前
浅克隆 深克隆
java
緈福的街口18 分钟前
【leetcode】2236. 判断根节点是否等于子节点之和
算法·leetcode·职场和发展
timing99420 分钟前
SQLite3 中列(变量)的特殊属性
java·jvm·sqlite
SimonKing26 分钟前
你的Redis分布式锁还在裸奔?看门狗机制让锁更安全!
java·后端·程序员
祁思妙想35 分钟前
【LeetCode100】--- 1.两数之和【复习回滚】
数据结构·算法·leetcode