Java 与排序算法(1):冒泡排序

news/2024/12/29 13:08:51/

一、冒泡排序

冒泡排序(Bubble Sort)是一种简单的排序算法,它的基本思想是通过不断交换相邻两个元素的位置,使得较大的元素逐渐往后移动,直到最后一个元素为止。冒泡排序的时间复杂度为 O ( n 2 ) O(n^2) O(n2),空间复杂度为 O ( 1 ) O(1) O(1),是一种稳定的排序算法。

其实现过程可以概括为以下几个步骤:

  1. 从序列的第一个元素开始,对相邻的两个元素进行比较,如果它们的顺序错误就交换它们的位置,即将较大的元素往后移动,直到遍历到序列的最后一个元素。
  2. 对剩下的元素重复上述步骤,直到整个序列都已经有序。

在这里插入图片描述

二、冒泡排序的性质

冒泡排序的时间复杂度为 O ( n 2 ) O(n^2) O(n2),空间复杂度为 O ( 1 ) O(1) O(1),是一种稳定的排序算法。

  1. 时间复杂度:冒泡排序的时间复杂度是 O(n^2),其中 n 是待排序序列的长度。冒泡排序的比较次数和交换次数都是 n(n-1)/2,因此时间复杂度为 O(n^2)。
  2. 稳定性:冒泡排序是一种稳定的排序算法,即相等的元素在排序前后的相对位置不会发生改变。
  3. 空间复杂度:冒泡排序的空间复杂度是 O(1),即只需要使用常数级别的额外空间来存储临时变量。

三、冒泡排序的变种

冒泡排序有一些变种,其中比较常见的有以下几种:

  1. 鸡尾酒排序(Cocktail Sort):又称为双向冒泡排序,它是一种改进的冒泡排序算法。与普通冒泡排序不同的是,它是从左到右遍历序列,然后从右到左遍历序列,交替进行,直到序列有序为止。这样可以在一定程度上减少排序的时间。
  2. 短冒泡排序(Short Bubble Sort):在冒泡排序的基础上进行改进,当某一轮遍历中没有发生元素交换时,说明序列已经有序,可以提前结束排序。这样可以在序列已经有序的情况下减少不必要的比较次数。
  3. 奇偶排序(Odd-Even Sort):也称为交替排序,它是一种并行排序算法,可以同时比较和交换序列中的奇数和偶数位置上的元素,直到序列有序为止。这样可以在一定程度上减少排序的时间,但是它只适用于能够并行处理的情况。

这些变种算法都是基于冒泡排序的基本思想,并对其进行了不同的优化和改进,使得排序效率更高。

四、Java 实现

以下是冒泡排序的 Java 实现:

public class BubbleSort {public static void bubbleSort(int[] arr) {int n = arr.length;for (int i = 0; i < n; 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;}}}}public static void main(String[] args) {int[] arr = {64, 34, 25, 12, 22, 11, 90};bubbleSort(arr);System.out.println(Arrays.toString(arr));  // [11, 12, 22, 25, 34, 64, 90]}
}

在上面的代码中,我们定义了一个 bubbleSort 方法来实现冒泡排序。该方法接受一个整型数组作为参数,然后使用双重循环来遍历数组并进行冒泡排序。在每轮遍历中,我们将最大的元素移动到数组末尾。最后,我们在 main 方法中调用 bubbleSort 方法对数组进行排序,并使用 Arrays.toString() 方法将排序后的数组输出到控制台。

五、冒泡排序的应用场景

冒泡排序虽然时间复杂度较高,但是它的实现简单,容易理解,并且在某些特定场景下仍然有着广泛的应用。以下是一些冒泡排序的应用场景:

  1. 数据量较小的排序:当待排序的数据量较小时,冒泡排序的效率并不比其他排序算法低,甚至在某些情况下可能更优。
  2. 数据基本有序的排序:当待排序的数据基本有序时,冒泡排序的效率比其他排序算法更高。因为冒泡排序可以在一轮遍历中将已经有序的元素排除在外,从而减少比较和交换的次数。
  3. 学习排序算法:冒泡排序是最基本的排序算法之一,它的实现简单,容易理解,是学习排序算法的入门算法。

需要注意的是,如果待排序的数据量较大,或者数据分布比较随机,冒泡排序的效率会比较低,不如其他排序算法。因此,在实际应用中,需要根据具体的情况选择适合的排序算法。

六、冒泡排序在spring 中的应用

在 Spring 框架中,冒泡排序算法并没有直接应用到核心模块中,但是它可以作为一种排序算法被使用在 Spring 的某些模块中,例如:

  1. Spring Security 模块中的权限排序:Spring Security 是一个基于 Spring 的安全框架,它提供了一套完整的安全解决方案,包括认证、授权、攻击防护等功能。在 Spring Security 中,权限可以通过冒泡排序算法来进行排序,以便于在授权时按照顺序进行匹配。
  2. Spring Batch 模块中的数据排序:Spring Batch 是一个基于 Spring 的批处理框架,它可以帮助用户快速构建和执行大规模、复杂的批处理作业。在 Spring Batch 中,数据排序是一个常见的操作,可以使用冒泡排序算法来实现。

需要注意的是,冒泡排序算法虽然简单,但是在实际应用中效率较低,因此在处理大规模数据时不建议使用。在 Spring 框架中,如果需要进行排序操作,建议使用更高效的排序算法,例如快速排序、归并排序等。


http://www.ppmy.cn/news/81953.html

相关文章

12 Binder的原理

Binder的原理 一、前言 从前一节,我们知道从Android 8.0 开始,Binder机制,被拆分成了Binder(System分区 进程间通信)、HwBinder(支持System/Vendor分区进程间通信)、VndBinder(Vendor分区进程间通信)。 现在我们先单独分析一下Binder的机制,HwBinder和VndBinder留到后面…

使用ln命令在Linux系统中创建连接文件

在Linux中ln命令用来为文件创建连接&#xff0c;连接类型分为硬连接&#xff08;Hard Link&#xff09;和符号连接&#xff08;Symbolic Link&#xff09;两种&#xff0c;默认的连接类型是硬连接。如果要创建符号连接必须使用"-s"选项。 关于软硬连接解释 硬连接 …

C++模板详解

文章目录 1、泛型编程2、函数模板3、函数模板实例化4、函数模板实例化5、类模板及其实例化 1、泛型编程 泛型编程&#xff1a;编写与类型无关的通用代码&#xff0c;是代码复用的一种手段。模板是泛型编程的基础。 优点&#xff1a; 1、高度可重用性&#xff1a;泛型编程使用模…

vue语法介绍,高级特性,编程技巧

Vue.js是一款流行的JavaScript框架&#xff0c;用于构建交互式Web界面。它采用了MVVM&#xff08;Model-View-ViewModel&#xff09;模式&#xff0c;使开发人员能够轻松地管理和维护Web应用程序的状态和行为。Vue.js具有简单易学、灵活性强、性能高等优点&#xff0c;因此在We…

有比较好用的web终端开源项目

有比较好用的web终端开源项目 有许多开源的web终端项目可供参考或直接使用&#xff1a; xterm.js&#xff1a;一个在前端运行的终端模拟器&#xff0c;它旨在创建一个类似于Unix shell的环境。然而&#xff0c;它仅仅提供终端用户界面&#xff0c;你需要为其配备一个后端来执行…

MySQL 中的 CASE WHEN 和功能类似的方法

一、关于 MySQL 中的 CASE WHEN 和功能类似的方法 1.1 CASE WHEN CASE WHEN 是 MySQL 中常用的逻辑判断语句&#xff0c;也被称为条件表达式。它可以根据不同的条件对数据进行分类和处理&#xff0c;并返回符合条件的结果。 在使用 CASE WHEN 时&#xff0c;我们需要指定待比…

如何使用Linux Top命令

Linux中的top命令允许您监视当前正在运行的进程及其使用的系统资源。作为系统管理员&#xff0c;它可能是工具箱中最有用的工具&#xff0c;特别是如果您知道如何使用它的话。所有Linux发行版都预装了top实用程序。通过这个交互式命令&#xff0c;您可以自定义如何浏览进程列表…

四维轻云平台常见问题及解决方法

1、在地图中看不见加载的点云或倾斜摄影模型数据&#xff1f; 若点云或模型数据加载后&#xff0c;在地图中看不见&#xff0c;可能是地形的高度高于倾斜模型的高度&#xff0c;导致数据漂浮在空中或者在地形以下&#xff0c;可通过增加数据的移动值Y来调整点云或者模型数据的…