java实现冒泡排序和快速排序代码

简介: java实现冒泡排序和快速排序

冒泡排序(Bubble Sort)和快速排序(Quick Sort)是两种常见的排序算法。以下是用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] + " ");
        }
    }
}

快速排序:

public class QuickSort {
   
    public static void quickSort(int[] arr, int low, int high) {
   
        if (low < high) {
   
            int pi = partition(arr, low, high);
            quickSort(arr, low, pi-1);
            quickSort(arr, pi+1, high);
        }
    }

    public static int partition(int[] arr, int low, int high) {
   
        int pivot = arr[high];  // 选取最后一个元素作为pivot
        int i = low-1;
        for (int j = low; j < high; j++) {
   
            if (arr[j] < pivot) {
   
                i++;
                // 交换arr[i]和arr[j]
                int temp = arr[i];
                arr[i] = arr[j];
                arr[j] = temp;
            }
        }
        // 交换arr[i+1]和arr[high]
        int temp = arr[i+1];
        arr[i+1] = arr[high];
        arr[high] = temp;
        return i+1;
    }

    public static void main(String[] args) {
   
        int[] arr = {
   64, 34, 25, 12, 22, 11, 90};
        int n = arr.length;
        quickSort(arr, 0, n-1);
        System.out.println("排序结果:");
        for (int i = 0; i < n; i++) {
   
            System.out.print(arr[i] + " ");
        }
    }
}

以上是用Java实现的冒泡排序和快速排序算法。你可以通过调用bubbleSortquickSort方法来排序一个整数数组。

相关文章
|
8月前
|
Java 开发工具
【Azure Storage Account】Java Code访问Storage Account File Share的上传和下载代码示例
本文介绍如何使用Java通过azure-storage-file-share SDK实现Azure文件共享的上传下载。包含依赖引入、客户端创建及完整示例代码,助你快速集成Azure File Share功能。
539 6
|
8月前
|
Java 数据处理 API
为什么你的Java代码应该多用Stream?从循环到声明式的思维转变
为什么你的Java代码应该多用Stream?从循环到声明式的思维转变
379 115
|
8月前
|
安全 Java 编译器
为什么你的Java代码需要泛型?类型安全的艺术
为什么你的Java代码需要泛型?类型安全的艺术
277 98
|
8月前
|
Java 编译器 API
java最新版和java8的区别,用代码展示
java最新版和java8的区别,用代码展示
669 43
|
8月前
|
安全 Java 容器
告别空指针噩梦:Optional让Java代码更优雅
告别空指针噩梦:Optional让Java代码更优雅
530 94
|
8月前
|
安全 Java 容器
告别繁琐判空:Optional让你的Java代码更优雅
告别繁琐判空:Optional让你的Java代码更优雅
|
9月前
|
IDE Java 关系型数据库
Java 初学者学习路线(含代码示例)
本教程为Java初学者设计,涵盖基础语法、面向对象、集合、异常处理、文件操作、多线程、JDBC、Servlet及MyBatis等内容,每阶段配核心代码示例,强调动手实践,助你循序渐进掌握Java编程。
1146 3
|
9月前
|
安全 Java 应用服务中间件
Spring Boot + Java 21:内存减少 60%,启动速度提高 30% — 零代码
通过调整三个JVM和Spring Boot配置开关,无需重写代码即可显著优化Java应用性能:内存减少60%,启动速度提升30%。适用于所有在JVM上运行API的生产团队,低成本实现高效能。
1065 3
|
9月前
|
Java
java入门代码示例
本文介绍Java入门基础,包含Hello World、变量类型、条件判断、循环及方法定义等核心语法示例,帮助初学者快速掌握Java编程基本结构与逻辑。
662 0