冒泡排序的简单理解

🚀 优质资源分享 🚀

学习路线指引(点击解锁)知识定位人群定位
🧡 Python实战微信订餐小程序 🧡进阶级本课程是python flask+微信小程序的完美结合,从项目搭建到腾讯云部署上线,打造一个全栈订餐系统。
💛Python量化交易实战💛入门级手把手带你打造一个易扩展、更安全、效率更高的量化交易系统

详细描述

冒泡排序是一种交换排序,基本思想是在要排序的一组数中,对当前还未排好序的范围内的全部数,自上而下对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒。

即每当两个相邻的数比较后发现它们的顺序与排序要求相反时,就将它们互换。

冒泡排序详细的执行步骤如下:

  1. 从第一个元素开始,比较相邻的元素,如果前一个比后一个大,就交换它们两个;
  2. 从前往后,对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对,这样在最后的元素就会是最大的数;
  3. 将这次找出的最大元素放在最后一个元素位置上,然后针对除这个最大元素以外的其他所有元素重复以上 1~2 步骤;
  4. 重复以上步骤,直到最后第一个元素和第二个元素完成比较、交换,则排序完成。

算法图解

冒泡排序

问题解疑

冒泡排序是原地排序算法吗?

冒泡排序是一个原地排序算法,过程只涉及相邻数据的交换操作,只需要常量级的临时空间,它的空间复杂度是 O(1)。

冒泡排序是稳定的排序算法吗?

为了保证冒泡排序算法的稳定性,当有相邻的两个元素大小相等时可以不做交换,相同大小的数据在排序前后不会改变顺序,所以冒泡排序是稳定的排序算法。

冒泡排序的时间复杂度是多少?

使用最优时间复杂度解法,原序列是有序时的时间复杂度是 O(n);最坏情况时间复杂度为 O(n2);平均时间复杂度是 O(n2)。

代码实现



|  | package cn.fatedeity.sort; |
|  |  |
|  | public class BubbleSort { |
|  | private static void swap(int[] numbers, int src, int target) { |
|  | int temp = numbers[src]; |
|  |  numbers[src] = numbers[target]; |
|  |  numbers[target] = temp; |
|  |  } |
|  |  |
|  | public static int[] sort(int[] numbers) { |
|  | for (int i = 0; i < numbers.length - 1; i++) { |
|  | boolean doSwap = false; |
|  | for (int j = 0; j + 1 < numbers.length - i; j++) { |
|  | if (numbers[j] > numbers[j + 1]) { |
|  |  swap(numbers, j, j + 1); |
|  |  doSwap = true; |
|  |  } |
|  |  } |
|  | // 优化基础冒泡排序的步骤 |
|  | if (!doSwap) { |
|  | // 如果遍历整个序列无需交换,则表示整个序列已经完全有序 |
|  | return numbers; |
|  |  } |
|  |  } |
|  | return numbers; |
|  |  } |
|  | } |


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值