冒泡排序的理解与实现【C语言、C++、java】

冒泡排序介绍

冒泡排序(Bubble Sort),又被称为气泡排序或泡沫排序。

它是一种较简单的排序算法。它会遍历若干次要排序的数列,每次遍历时,它都会从前往后依次的比较相邻两个数的大小;如果前者比后者大,则交换它们的位置。这样,一次遍历之后,最大的元素就在数列的末尾! 采用相同的方法再次遍历时,第二大的元素就被排列在最大元素之前。重复此操作,直到整个数列都有序为止!

冒泡排序图文说明

冒泡排序C实现一

void bubble_sort1(int a[], int n)
{int i,j;for (i=n-1; i>0; i--){// 将a[0...i]中最大的数据放在末尾for (j=0; j<i; j++){if (a[j] > a[j+1])swap(a[j], a[j+1]);}}
}

下面以数列{20,40,30,10,60,50}为例,演示它的冒泡排序过程(如下图)。

我们先分析第1趟排序
当i=5,j=0时,a[0]<a[1]。此时,不做任何处理!
当i=5,j=1时,a[1]>a[2]。此时,交换a[1]和a[2]的值;交换之后,a[1]=30,a[2]=40。
当i=5,j=2时,a[2]>a[3]。此时,交换a[2]和a[3]的值;交换之后,a[2]=10,a[3]=40。
当i=5,j=3时,a[3]<a[4]。此时,不做任何处理!
当i=5,j=4时,a[4]>a[5]。此时,交换a[4]和a[5]的值;交换之后,a[4]=50,a[3]=60。

于是,第1趟排序完之后,数列{20,40,30,10,60,50}变成了{20,30,10,40,50,60}。此时,数列末尾的值最大。

根据这种方法:
第2趟排序完之后,数列中a[5...6]是有序的。
第3趟排序完之后,数列中a[4...6]是有序的。
第4趟排序完之后,数列中a[3...6]是有序的。
第5趟排序完之后,数列中a[1...6]是有序的。

第5趟排序之后,整个数列也就是有序的了。

冒泡排序C实现二

观察上面冒泡排序的流程图,第3趟排序之后,数据已经是有序的了;第4趟和第5趟并没有进行数据交换。
下面我们对冒泡排序进行优化,使它效率更高一些:添加一个标记,如果一趟遍历中发生了交换,则标记为true,否则为false。如果某一趟没有发生交换,说明排序已经完成!

void bubble_sort2(int a[], int n)
{int i,j;int flag;                 // 标记for (i=n-1; i>0; i--){flag = 0;            // 初始化标记为0// 将a[0...i]中最大的数据放在末尾for (j=0; j<i; j++){if (a[j] > a[j+1]){swap(a[j], a[j+1]);flag = 1;    // 若发生交换,则设标记为1}}if (flag==0)break;            // 若没发生交换,则说明数列已有序。}
}

冒泡排序的时间复杂度和稳定性

冒泡排序时间复杂度

冒泡排序的时间复杂度是O(N2)。
假设被排序的数列中有N个数。遍历一趟的时间复杂度是O(N),需要遍历多少次呢?N-1次!因此,冒泡排序的时间复杂度是O(N2)。

冒泡排序稳定性

冒泡排序是稳定的算法,它满足稳定算法的定义。
算法稳定性 -- 假设在数列中存在a[i]=a[j],若在排序之前,a[i]在a[j]前面;并且排序之后,a[i]仍然在a[j]前面。则这个排序算法是稳定的!

冒泡排序实现

冒泡排序C实现
实现代码(bubble_sort.c)
 1 /**2  * 冒泡排序:C 语言3  *4  * @author skywang5  * @date 2014/03/116  */7 8 #include <stdio.h>9 
10 // 数组长度
11 #define LENGTH(array) ( (sizeof(array)) / (sizeof(array[0])) )
12 // 交互数值
13 #define swap(a,b)    (a^=b,b^=a,a^=b)
14 
15 /*
16  * 冒泡排序
17  *
18  * 参数说明:
19  *     a -- 待排序的数组
20  *     n -- 数组的长度
21  */
22 void bubble_sort1(int a[], int n)
23 {
24     int i,j;
25 
26     for (i=n-1; i>0; i--)
27     {
28         // 将a[0...i]中最大的数据放在末尾
29         for (j=0; j<i; j++)
30         {
31             if (a[j] > a[j+1])
32                 swap(a[j], a[j+1]);
33         }
34     }
35 }
36 
37 /*
38  * 冒泡排序(改进版)
39  *
40  * 参数说明:
41  *     a -- 待排序的数组
42  *     n -- 数组的长度
43  */
44 void bubble_sort2(int a[], int n)
45 {
46     int i,j;
47     int flag;                 // 标记
48 
49     for (i=n-1; i>0; i--)
50     {
51         flag = 0;            // 初始化标记为0
52 
53         // 将a[0...i]中最大的数据放在末尾
54         for (j=0; j<i; j++)
55         {
56             if (a[j] > a[j+1])
57             {
58                 swap(a[j], a[j+1]);
59                 flag = 1;    // 若发生交换,则设标记为1
60             }
61         }
62 
63         if (flag==0)
64             break;            // 若没发生交换,则说明数列已有序。
65     }
66 }
67 
68 void main()
69 {
70     int i;
71     int a[] = {20,40,30,10,60,50};
72     int ilen = LENGTH(a);
73 
74     printf("before sort:");
75     for (i=0; i<ilen; i++)
76         printf("%d ", a[i]);
77     printf("\n");
78 
79     bubble_sort1(a, ilen);
80     //bubble_sort2(a, ilen);
81 
82     printf("after  sort:");
83     for (i=0; i<ilen; i++)
84         printf("%d ", a[i]);
85     printf("\n");
86 }
冒泡排序C++实现
实现代码(BubbleSort.cpp)
 1 /**2  * 冒泡排序:C++3  *4  * @author skywang5  * @date 2014/03/116  */7 8 #include <iostream>9 using namespace std;
10 
11 /*
12  * 冒泡排序
13  *
14  * 参数说明:
15  *     a -- 待排序的数组
16  *     n -- 数组的长度
17  */
18 void bubbleSort1(int* a, int n)
19 {
20     int i,j,tmp;
21 
22     for (i=n-1; i>0; i--)
23     {
24         // 将a[0...i]中最大的数据放在末尾
25         for (j=0; j<i; j++)
26         {
27             if (a[j] > a[j+1])
28             {    
29                 // 交换a[j]和a[j+1]
30                 tmp = a[j];
31                 a[j] = a[j+1];
32                 a[j+1] = tmp;
33             }
34         }
35     }
36 }
37 
38 /*
39  * 冒泡排序(改进版)
40  *
41  * 参数说明:
42  *     a -- 待排序的数组
43  *     n -- 数组的长度
44  */
45 void bubbleSort2(int* a, int n)
46 {
47     int i,j,tmp;
48     int flag;                 // 标记
49 
50     for (i=n-1; i>0; i--)
51     {
52         flag = 0;            // 初始化标记为0
53 
54         // 将a[0...i]中最大的数据放在末尾
55         for (j=0; j<i; j++)
56         {
57             if (a[j] > a[j+1])
58             {
59                 // 交换a[j]和a[j+1]
60                 tmp = a[j];
61                 a[j] = a[j+1];
62                 a[j+1] = tmp;
63 
64                 flag = 1;    // 若发生交换,则设标记为1
65             }
66         }
67 
68         if (flag==0)
69             break;            // 若没发生交换,则说明数列已有序。
70     }
71 }
72 
73 int main()
74 {
75     int i;
76     int a[] = {20,40,30,10,60,50};
77     int ilen = (sizeof(a)) / (sizeof(a[0]));
78 
79     cout << "before sort:";
80     for (i=0; i<ilen; i++)
81         cout << a[i] << " ";
82     cout << endl;
83 
84     bubbleSort1(a, ilen);
85     //bubbleSort2(a, ilen);
86 
87     cout << "after  sort:";
88     for (i=0; i<ilen; i++)
89         cout << a[i] << " ";
90     cout << endl;
91 
92     return 0;
93 }
冒泡排序Java实现
实现代码(BubbleSort.java)
1 /**2  * 冒泡排序:Java3  *4  * @author skywang5  * @date 2014/03/116  */7 8 public class BubbleSort {9 
10     /*
11      * 冒泡排序
12      *
13      * 参数说明:
14      *     a -- 待排序的数组
15      *     n -- 数组的长度
16      */
17     public static void bubbleSort1(int[] a, int n) {
18         int i,j;
19 
20         for (i=n-1; i>0; i--) {
21             // 将a[0...i]中最大的数据放在末尾
22             for (j=0; j<i; j++) {
23 
24                 if (a[j] > a[j+1]) {
25                     // 交换a[j]和a[j+1]
26                     int tmp = a[j];
27                     a[j] = a[j+1];
28                     a[j+1] = tmp;
29                 }
30             }
31         }
32     }
33 
34     /*
35      * 冒泡排序(改进版)
36      *
37      * 参数说明:
38      *     a -- 待排序的数组
39      *     n -- 数组的长度
40      */
41     public static void bubbleSort2(int[] a, int n) {
42         int i,j;
43         int flag;                 // 标记
44 
45         for (i=n-1; i>0; i--) {
46 
47             flag = 0;            // 初始化标记为0
48             // 将a[0...i]中最大的数据放在末尾
49             for (j=0; j<i; j++) {
50                 if (a[j] > a[j+1]) {
51                     // 交换a[j]和a[j+1]
52                     int tmp = a[j];
53                     a[j] = a[j+1];
54                     a[j+1] = tmp;
55 
56                     flag = 1;    // 若发生交换,则设标记为1
57                 }
58             }
59 
60             if (flag==0)
61                 break;            // 若没发生交换,则说明数列已有序。
62         }
63     }
64 
65     public static void main(String[] args) {
66         int i;
67         int[] a = {20,40,30,10,60,50};
68 
69         System.out.printf("before sort:");
70         for (i=0; i<a.length; i++)
71             System.out.printf("%d ", a[i]);
72         System.out.printf("\n");
73 
74         bubbleSort1(a, a.length);
75         //bubbleSort2(a, a.length);
76 
77         System.out.printf("after  sort:");
78         for (i=0; i<a.length; i++)
79             System.out.printf("%d ", a[i]);
80         System.out.printf("\n");
81     }
82 }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/737455.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一体机电脑辐射超标整改

电脑一体机是目前台式机和笔记本电脑之间的一个新型的市场产物&#xff0c;它将主机部分、显示器部分整合到一起的新形态电脑&#xff0c;该产品的创新在于内部元件的高度集成。随着无线技术的发展&#xff0c;电脑一体机的键盘、鼠标与显示器可实现无线链接&#xff0c;机器只…

美国站群服务器使用技巧与注意事项

美国站群服务器使用技巧与注意事项有哪些?RAKsmart小编为您整理发布美国站群服务器使用技巧与注意事项&#xff0c;希望对您有帮助。 美国站群服务器的使用技巧主要包括远程管理、灵活配置和备份还原&#xff0c;具体如下&#xff1a; 1. **远程管理**&#xff1a;用户可以通过…

计算机网络-第5章 运输层(2)

5.6 TCP可靠传输实现 以字节为单位的滑动窗口。 发送窗口已满&#xff0c;停止发送。 发送和接收的数据都来自缓存。 超时重传时间RTO选择&#xff1a;自适应算法&#xff0c; 选择确认SACK&#xff1a;只传送缺少的数据。大多数实现还是重传所有未被确认的数据块。 5.7 TCP的…

LLM 推理优化

LLM 推理服务重点关注两个指标&#xff1a;吞吐量和时延&#xff1a; 吞吐量&#xff1a;主要从系统的角度来看&#xff0c;即系统在单位时间内能处理的 tokens 数量。计算方法为系统处理完成的 tokens个数除以对应耗时&#xff0c;其中 tokens 个数一般指输入序列和输出序列长…

掌握Mongodb,看完这篇文章就够了

目录 1.概念 2.操作 2.1数据库操作 2.2集合操作 2.3数据操作 3.查询 4.常用技术 5.python与MongoDB 1.概念 MongoDB是一种非关系型数据库&#xff08;NoSQL&#xff09;&#xff0c;它以灵活的文档存储格式&#xff08;BSON&#xff09;和强大的查询能…

MinGW-w64的下载与安装

文章目录 1 下载2 安装3 配置环境变量4 验证 1 下载 官网地址&#xff1a;https://www.mingw-w64.org/github地址&#xff1a;https://github.com/niXman/mingw-builds-binaries/releases windows下载 跳转github下载 版本号选择&#xff1a;13.2.0是GCC的版本号&#xff1b…

如何避免MYSQL主从延迟带来的读写问题?

在MYSQL 部署架构选型上&#xff0c;许多公司都会用到主从读写分离的架构&#xff0c;如下是一个一主一从的架构&#xff0c;主库master负责写入&#xff0c;从库slave进行读取。 但是既然是读写分离&#xff0c;必然会面临这样一个问题&#xff0c;当在主库上进行更新后&#…

QML | 在QML中导入JavaScript资源、导入JavaScript资源、包含一个JavaScript 资源

01 在QML中导入JavaScript资源 JavaScript资源可以被QML文档和其他JavaScript通过相对或者绝对路径进行导入。如果使用相对路径,位置解析需要相对于包含import语句的QML文档或JavaScript资源的位置。如果JavaScript需要从网络资源中进行获取,组件的status属性会被设置为Loadi…

PyCM:Python中的混淆矩阵库

PyCM&#xff1a;Python中的混淆矩阵库 在机器学习和数据科学领域&#xff0c;评估模型的性能是至关重要的。混淆矩阵是一种常用的评估工具&#xff0c;用于可视化和量化分类模型的预测结果。PyCM是一个开源的Python库&#xff0c;提供了丰富的功能来计算和分析混淆矩阵。本文将…

【C++】STL(二) string容器

一、string基本概念 1、本质 string是C风格的字符串&#xff0c;而string本质上是一个类 string和char * 区别&#xff1a; char * 是一个指针 string是一个类&#xff0c;类内部封装了char*&#xff0c;管理这个字符串&#xff0c;是一个char*型的容器。 2、特点 1、stri…

R语言绘制桑基图教程

原文链接&#xff1a;R语言绘制桑基图教程 写在前面 在昨天3月10日&#xff0c;我们在知乎、B站等分享了功能富集桑基气泡图的绘制教程。相关链接&#xff1a;NC|高颜值功能富集桑基气泡图&#xff0c;桑基气泡组合图。 确实&#xff0c;目前这个图在文章中出现的频率相对比较…

Wilson威尔逊平滑

1、威尔逊平滑引入的动机 在曝光很少的情况下&#xff0c;计算出的CTR并不真实可靠&#xff0c;而样本数越大&#xff0c;CTR的比例才越准确&#xff0c;更能反应真实情况。 为了衡量样本数对于CTR信区间的影响&#xff0c;我们引入"威尔逊&#xff08;Wilson&#xff0…

地球系统模式(CESM)

目前通用地球系统模式&#xff08;Community Earth System Model&#xff0c;CESM&#xff09;在研究地球的过去、现在和未来的气候状况中具有越来越普遍的应用。CESM由美国NCAR于2010年07月推出以来&#xff0c;一直受到气候学界的密切关注。近年升级的CESM2.0在大气、陆地、海…

STM32CubeMX 配置 STM32F103 工程:通过DAC输出正弦波

说明&#xff1a;STM32CubeMX 配置 STM32F103 工程&#xff0c;通过DAC输出正弦波&#xff0c;参考代码可自动计算频率&#xff0c;自动计算正弦数据。 先参考这篇文章配置时钟、工程输出的设置&#xff1a; STM32CubeMX 配置 STM32F103 工程&#xff1a;通过DAC生成三角波、…

关于遗传力常见的误解

大家好&#xff0c;我是邓飞&#xff0c;今天看了一篇非常好的文章&#xff0c;介绍了遗传力相关概念和计算方法&#xff0c;里面提到了常见的误解&#xff0c;这里汇总一下。 文献链接&#xff1a;https://excellenceinbreeding.org/sites/default/files/manual/EiB-M2_Herit…

STM32CubeMX学习笔记20——SD卡FATFS文件系统

1. FATFS文件系统简介 文件系统是操作系统用于明确存储设备或分区上的文件的方法和数据结构&#xff08;即在存储设备上组织文件的方法&#xff09;。操作系统中负责管理和存储文件信息的软件机构称为文件管理系统&#xff0c;简称文件系统&#xff1b;不带文件系统的SD卡仅能…

seo js转码工具

js转码工具作用 用于把js加密 如果不想让别人看到自己的js 代码就可以使用这个方法 js工具网址 https://tool.chinaz.com/js.aspx 效果

【大厂AI课学习笔记NO.74】人工智能产业技术架构

包括基础层、技术层和应用层。 人工智能的产业技术架构是一个多层次、多维度的复杂系统&#xff0c;它涵盖了从基础硬件和软件设施到高级算法和应用技术的全过程。这个架构通常可以分为三个主要层次&#xff1a;基础层、技术层和应用层。下面我将详细论述这三个层次及其细分内…

基于Yolo5模型的动态口罩佩戴识别安卓Android程序设计

禁止完全抄袭&#xff0c;引用注明出处。 下载地址 前排提醒&#xff1a;文件还没过CSDN审核&#xff0c;GitHub也没上传完毕&#xff0c;目前只有模型的.pt文件可以下载。我会尽快更新。 所使用.ptl文件 基于Yolo5的动态口罩佩戴识别模型的pt文件资源-CSDN文库 项目完整文…

升级ChatGPT4.0失败的解决方案

ChatGPT 4.0科普 ChatGPT 4.0是一款具有多项出众功能的新一代AI语言模型。以下是关于ChatGPT 4.0的一些关键特点和科普内容&#xff1a; 多模态&#xff1a;ChatGPT 4.0具备处理不同类型输入和输出的能力。这意味着它不仅可以接收文字信息&#xff0c;还能处理图片、视频等多…