第八章 排序 四、冒泡排序

目录

一、算法思想

二、例子

三、代码实现

四、验证

五、算法性能分析

注意:要分清楚交换次数和移动次数

六、总结


一、算法思想

从后往前,两两比较相邻元素的值,若为逆序,则交换它们的值,直到全部比较完。

二、例子

1、有以下序列,我们要将其进行冒泡排序将其变为升序序列。

2、我们从后往前依次对比,比较27和49,发现49大于27,正序,所以不用交换位置

3、然后比较13和27,发现27大于13,正序,所以不用交换位置

4、比较13和76,13小于76,交换它们的值

5、比较13和97,13小于97,交换它们的值

6、比较13和65,13小于65,交换它们的值

7、比较13和38,13小于38,交换它们的值

8、比较13和49,13小于49,交换它们的值

9、最后完成第一轮的对比

10、第一轮对比我们把序列中最小的值放到了最前面,所以下一次循环就不用再对比13了,最终模仿上面进行5轮交换后,得到最终的升序序列。

三、代码实现

cpp 复制代码
#include "bits/stdc++.h"
using namespace std;

void BubbleSort(int a[],int n){
    int temp;
    for (int i = 0; i < n; ++i) {//设置对比的边界
        for (int j = n-1; j > i ; --j) {//从后往前比较相邻的两个数
            if (a[j]<a[j-1]){//若逆序则交换
                temp = a[j];
                a[j] = a[j-1];
                a[j-1] = temp;
            }
        }
    }
}

int main(){
    int count,arr[10];
    scanf("%d",&count);//输入数组长度
    for (int i = 0; i < count; ++i) {
        scanf("%d",&arr[i]);//输入数组
    }
    BubbleSort(arr,count);//调用排序函数
    for (int i = 0; i < count; ++i) {
        printf("%d ",arr[i]);//输出数组
    }
    return 0;
}

四、验证

五、算法性能分析

注意:要分清楚交换次数和移动次数

六、总结

相关推荐
C++忠实粉丝3 小时前
前缀和(8)_矩阵区域和
数据结构·c++·线性代数·算法·矩阵
ZZZ_O^O3 小时前
二分查找算法——寻找旋转排序数组中的最小值&点名
数据结构·c++·学习·算法·二叉树
代码雕刻家4 小时前
数据结构-3.9.栈在递归中的应用
c语言·数据结构·算法
Kalika0-06 小时前
猴子吃桃-C语言
c语言·开发语言·数据结构·算法
代码雕刻家6 小时前
课设实验-数据结构-单链表-文教文化用品品牌
c语言·开发语言·数据结构
小字节,大梦想7 小时前
【C++】二叉搜索树
数据结构·c++
我是哈哈hh8 小时前
专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结
服务器·数据结构·c++·算法·机器学习·深度优先·剪枝
丶Darling.8 小时前
LeetCode Hot100 | Day1 | 二叉树:二叉树的直径
数据结构·c++·学习·算法·leetcode·二叉树
labuladuo5209 小时前
Codeforces Round 977 (Div. 2) C2 Adjust The Presentation (Hard Version)(思维,set)
数据结构·c++·算法
Indigo_code9 小时前
【数据结构】【链表代码】合并有序链表
数据结构·windows·链表