冒泡排序算法(java)

本文介绍了冒泡排序算法的基本原理和两种Java实现方式,包括升序排序的逻辑。第一种方法通过每轮找到最小值放置在正确位置,第二种方法则在每轮将最大值放到末尾。文章还提到,第二种方法可以通过优化提前结束排序,当没有数字交换时说明已排序完成,提供了一个思考方向。
摘要由CSDN通过智能技术生成

前言:

        冒泡排序(Bubble Sort),是一种计算机领域的较简单的排序算法。

        它重复地走访过要排序的元素列,依次比较两个相邻的元素,如果顺序(如从大到小、首字母从Z到A)错误就把他们交换过来。走访元素的工作是重复地进行直到没有相邻元素需要交换,也就是说该元素列已经排序完成。

        这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端(升序或降序排列),就如同碳酸饮料中的气泡最终会上浮到顶端一样,故名“冒泡排序”。

        话不多说,我们来看实际应用!!

——————————————————————————————————————————————————————————

正文:

        冒泡排序算法有两种写法,这里展示的是升序的排序方法,从代码上来看:

        首先声明一下两种的时间复杂度都为O(n²),但第二种方法有一种优化方式,是第一种的比较方式完成不了的,这个在结尾会具体说明。

        首先是BubbleSort1:

        它是以i为指引,每次对比出来最小的数就存在i的位置上,对比的逻辑是,如果a[i]<a[j],则将a[j]的值赋给a[i],每一轮都能找到最小的值,放在i的那个位置上,从而实现排序

        然后是BubbleSort2:

        它是以相邻的两个数对比,因为每一轮都能对比出来最大的数字,然后将每一轮对比出来的最大的数字放在了末尾,依次进行&

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

陈承宇- 。-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值