iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >图解Java经典算法冒泡排序的原理与实现
  • 609
分享到

图解Java经典算法冒泡排序的原理与实现

2024-04-02 19:04:59 609人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

目录冒泡排序算法原理动图演示算法练习算法分析冒泡排序 冒泡排序是一种比较简单的排序算法,我们可以重复遍历要排序的序列,每次比较两个元素,如果他们顺序错误就交换位置,重复遍历到没有可以

冒泡排序

冒泡排序是一种比较简单的排序算法,我们可以重复遍历要排序的序列,每次比较两个元素,如果他们顺序错误就交换位置,重复遍历到没有可以交换的元素,说明排序完成。

算法原理

  • 从第一个元素开始,比较相邻的两个元素,如果第一个大于第二个,则交换它们
  • 对每一对相邻的元素做相同的操作,从第一对到最后一对,最终最后一位元素就是最大值
  • 对每一个元素重复上述步骤,最后一个除外 

动图演示

算法练习

题目描述: 给定一个无序数组,利用冒泡排序将数组按升序排列。

示例一:

输入: arrs= [5,0,9,3,-1,12]
输出: arrs= [-1,0,3,5,9,12]

示例二:

输入: arrs= [3,5,9,7,2,1]
输出: arrs= [1,2,3,5,7,9]

解题思路:

通过比较相邻的元素,如果前一个比后一个大,则交换位置。

  • 第一趟:比较第1个和第2个元素,然后是第2个和第3个比较,这样直到倒数第2个和最后1个,将最大的数移动到最后一位。
  • 第二趟:重复上面步骤,将第二大的数交换至倒数第二位。

  • 每一趟都会将元素中第 n 大的元素交换到倒数第 n 位。
  • 一共需要n-1趟。

代码实现:

public class BubbleTest {
    public static void main(String[] args) {
        Integer[] arr = {3,5,9,7,2,1};
        Bubble.sort(arr);
        System.out.println(Arrays.toString(arr));
    }
    //数组排序
    public static void bubblesort(Comparable[] a){
        for (int i = a.length - 1;i > 0;i--){
            for (int j = 0;j < i;j++){
                if (greater(a[j],a[j + 1])){
                    swap(a,j,j + 1);
                }
            }
        }
    }
    //比较 v 是否大于 w
    public static boolean greater(Comparable v,Comparable w){
        return v.compareTo(w) > 0;
    }
    //数组元素交换位置
    private static void swap(Comparable[] a,int i,int j){
        Comparable temp;
        temp = a[i];
        a[i] = a[j];
        a[j] = temp;
    }
}

算法分析

时间复杂度

冒泡排序是一种用时间换空间的排序方法,最坏情况是把顺序的排列变成逆序,或者把逆序的数列变成顺序。在这种情况下,每一次比较都需要进行交换运算。

而对于有n个元素的数列它的比较次数为 (n-1) + (n-2) + … + 1 = n * (n - 1) / 2;因此它的时间复杂度为O(n^2)。

空间复杂度

冒泡排序的辅助变量只是一个临时变量,不会随数组规模的增大而增大,所以冒泡排序的空间复杂度为O(1)。

到此这篇关于图解Java经典算法冒泡排序的原理与实现的文章就介绍到这了,更多相关Java冒泡排序内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 图解Java经典算法冒泡排序的原理与实现

本文链接: https://www.lsjlt.com/news/167270.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 图解Java经典算法冒泡排序的原理与实现
    目录冒泡排序算法原理动图演示算法练习算法分析冒泡排序 冒泡排序是一种比较简单的排序算法,我们可以重复遍历要排序的序列,每次比较两个元素,如果他们顺序错误就交换位置,重复遍历到没有可以...
    99+
    2022-11-13
  • 图解Java经典算法冒泡选择插入希尔排序的原理与实现
    目录一、冒泡排序1、基本介绍2、代码实现二、 选择排序1、基本介绍2、代码实现三、插入排序1、基本介绍2、代码实现四、希尔排序1、基本介绍2、代码实现(交换排序)3、代码实现(移位排...
    99+
    2022-11-13
  • 图解Java经典算法归并排序的原理与实现
    目录归并排序算法原理动图演示代码实现复杂度归并排序 归并排序主要分成两部分实现,分、合两部分,分是把数组分成两半,再递归的对子数组进行 分 操作,直到分成一个个单独的数。合是把两个数...
    99+
    2022-11-13
  • 图解Java经典算法希尔排序的原理与实现
    目录希尔排序算法思想图解代码实现(Java)希尔排序 希尔排序时插入排序的一种,也称缩小增量排序,是直接插入排序的一种更高效的改进版本。希尔排序是非稳定排序算法。 算法思想 希尔排序...
    99+
    2022-11-13
  • 图解Java经典算法快速排序的原理与实现
    目录快速排序算法原理图解Java代码实现算法分析快速排序 通过一趟排序将待排元素分成独立的两部分,其中一部分为比基准数小的元素,另一部分则是比基准数大的元素。然后对这两部分元素再按照...
    99+
    2022-11-13
  • 图解Java经典算法插入排序的原理与实现
    目录一、算法介绍二、算法思想三、算法原理四、动图演示五、代码实现六、算法分析6.1 时间复杂度6.2 空间复杂度一、算法介绍 插入排序,也称为直接插入排序。插入排序是简单排序中效率最...
    99+
    2022-11-13
  • Java十大经典排序算法的实现图解
    目录前言一、排序算法1.排序算法概述(百度百科)2.《数据结构与算法》中的排序算法3.算法分析二、十大经典排序算法(Java开发版)1.冒泡排序2.快速排序3.基数排序4.插入排序5...
    99+
    2022-11-13
  • 图解Java经典算法折半查找的原理与实现
    目录二分查找算法思路图解力扣原题二分查找 二分查找也称折半查找(Binary Search),它是一种效率较高的查找方法,可以在数据规模的对数时间复杂度内完成查找。是一种在有序数组中...
    99+
    2022-11-13
  • Java 数组中的冒泡排序算法如何理解
    这篇文章跟大家分析一下“Java 数组中的冒泡排序算法如何理解”。内容详细易懂,对“Java 数组中的冒泡排序算法如何理解”感兴趣的朋友可以跟着小编的思路慢慢深入来阅读一下,希望阅读后能够对大家有所帮助。下面跟着小编一起深入学习“Java ...
    99+
    2023-06-02
  • Python实现冒泡排序算法的示例解析
    目录1. 算法描述2. 算法分析3. 动图展示4. 代码实现5. 算法升级6. 时间复杂度分析1. 算法描述 冒泡排序(Bubble Sort)是一种简单的排序算法。它重复地遍历要排...
    99+
    2022-11-11
  • 冒泡排序与二分算法如何在java 项目中实现
    冒泡排序与二分算法如何在java 项目中实现?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1、冒泡算法的原理:冒泡排序算法的一般性策略:搜索整个值列,比较相邻元素,如果两者...
    99+
    2023-05-31
    java 冒泡排序 二分算法
  • 图解Java中归并排序算法的原理与实现
    目录一、基本思想二、算法分析1、算法描述2、过程分析3、动图演示三、算法实现一、基本思想 归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and C...
    99+
    2022-11-13
  • 图解Java中插入排序算法的原理与实现
    目录一、基本思想二、算法分析1、算法描述2、过程分析三、算法实现一、基本思想 插入排序(Insertion-Sort)的算法描述是一种简单直观的排序算法。它的工作原理是通过构建有序序...
    99+
    2022-11-13
  • 如何在Java与Python项目中实现一个冒泡排序算法
    如何在Java与Python项目中实现一个冒泡排序算法?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。冒泡排序可以说是在排序算法中最为入门级别的算法之一了。因为其简单易于理解...
    99+
    2023-05-31
    java 冒泡排序 python
  • C语言实现冒泡排序算法的示例详解
    目录1. 问题描述2. 问题分析3. 算法设计动图演示4. 程序设计设计一设计二结论5. 流程框架6. 代码实现7. 问题拓展1. 问题描述 对N个整数(数据由键盘输入)进行升序排列...
    99+
    2022-11-13
  • 详解Python排序算法的实现(冒泡,选择,插入,快速)
    目录1. 前言2. 冒泡排序算法2.1 摆擂台法2.2 相邻两个数字相比较3. 选择排序算法4. 插入排序5. 快速排序6. 总结1. 前言 所谓排序,就是把一个数据群体按个体数据的...
    99+
    2022-11-10
  • 五种编程语言(Python、Java、C++、JavaScript、PHP)实现冒泡排序算法及其原理和总结
    本文介绍了五种不同编程语言(Python、Java、C++、JavaScript、PHP)实现冒泡排序算法的代码及其原理和总结。冒泡排序是一种简单的排序算法,通过重复遍历待排序的数组,每次比较相邻的两...
    99+
    2023-09-02
    算法 排序算法 数据结构
  • 基数排序算法的原理与实现详解(Java/Go/Python/JS/C)
    目录说明实现过程示意图性能分析代码JavaPythonGoJSTSCC++链接说明 基数排序(RadixSort)是一种非比较型整数排序算法,其原理是将整数按位数切割成不同的数字,然...
    99+
    2023-03-06
    基数排序算法原理 基数排序算法实现 基数排序算法 基数排序
  • Python实现的堆排序算法原理与用法实例分析
    本文实例讲述了Python实现的堆排序算法。分享给大家供大家参考,具体如下: 堆排序(Heapsort)是指利用堆这种数据结构所设计的一种排序算法。堆是一个近似完全二叉树的结构,并同时满足堆性质:即子结点的...
    99+
    2022-06-04
    算法 实例 原理
  • 图文讲解选择排序算法的原理及在Python中的实现
    基本思想:从未排序的序列中找到一个最小的元素,放到第一位,再从剩余未排序的序列中找到最小的元素,放到第二位,依此类推,直到所有元素都已排序完毕。假设序列元素总共n+1个,则我们需要找n轮,就可以使该序列排好...
    99+
    2022-06-04
    算法 原理 图文
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作