C++:第七讲冒泡排序

Everyday English

A man, as a general rule, owes very little to
what he is born with – a man is what he makes of himself. — Alexander Graham
Bell.
人一般而言,天生的能力对他影响不大 – 他如何造就自己决定他的人生。

前言

因为博主最近在参加KET考试,所以断更了一周,但我还是要把最优质的内容呈现给大家。

冒泡排序

冒泡排序是排序的一种,什么是冒泡排序呢?冒泡排序的英语名是Bubble Sort,是一种最基础的交换排序。大家一定都喝过汽水吧,汽水中常常有许多小小的气泡,往上飘,这是因为组成小气泡的二氧化碳比水要轻,所以小气泡才会一点一点的向上浮。冒泡排序就是运用了这一原理,将轻的气泡往上浮(或将重的往下沉),具体如何移动呢?我们来看一下例子:

第一轮排序:

1.首先让32和12进行交换,发现12比32小,因此元素位置变。

2.接下来让32和9比较,发现32比9大,所以要交换32和9的位置。

3.继续让32和33比较,发现33比32要大,因此元素位置变。

4.继续让33和23进行比较,发现23比33小,因此元素位置变。

now(经历了第一轮):

第二轮排序:

5.首先让12和9进行交换,发现9比12小,因此元素位置变。

6.接下来让12和32比较,发现32比12大,因此元素位置不变。

7.继续让32和23比较,发现32比23要大,因此元素位置变。

8.继续让32和33进行比较,发现32比33小,因此元素位置不变。

最后(now):

这样一来,就已经排序好了。

到此为止,所有的元素都是有序的了,这就是冒泡排序的整体思路。

原始的冒泡排序是稳定的,由于该排序算法的每一轮都要遍历一遍所有的元素,轮转的次数和元素数量相当,所以时间复杂度为O(N^2)。

在冒泡排序中,要用到一个函数(swap),他在英语里是交换的意思。

洛谷小课堂

刚学完排序,还不趁热打铁练习一下?

思路点拨

这题就要用到swap函数。

swap是这么用的:

swap(变量a,变量b);

AC代码

#include <iostream>

using namespace std;

int main()
{
    int a,b,c;
    cin>>a>>b>>c;
    if(a>b)swap(a,b);
    if(b>c)swap(b,c);
    if(a>b)swap(a,b);
    cout<<a<<' '<<b<<' '<<c;
}

结尾

博主还是一名小学生,真的尽力了。

如果你能支持一下我,我十分感谢!!!

最后认识一下,我是爱编程的喷火龙廖,我们有缘再见!

  • 23
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

喷火龙廖

你的鼓励是我最大的动力

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

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

打赏作者

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

抵扣说明:

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

余额充值