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

news2024/11/15 12:08:50

冒泡排序介绍

冒泡排序(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 skywang
 5  * @date 2014/03/11
 6  */
 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 skywang
 5  * @date 2014/03/11
 6  */
 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  * 冒泡排序:Java
 3  *
 4  * @author skywang
 5  * @date 2014/03/11
 6  */
 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.coloradmin.cn/o/1509053.html

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

相关文章

【生成式AI導論 2024】第4講:訓練不了人工智慧?你可以訓練你自己 (中) — 拆解問題與使用工具

文章目录 我的总结 拆解任务让语言模型检查自己的错误为什么同一个问题每次答案都不同&#xff1f;组合拳使用工具使用工具-搜索引擎-RAG使用工具-文字生图AIGPT4 其他插件 from: https://www.youtube.com/watch?vlwe3_x50_uw 我的总结 复杂任务拆解为多个步骤让模型检查自己…

微服务配置中心

什么是配置中心 配置中心是一种用于管理应用程序或系统配置信息的中央服务。它允许开发人员在多个环境&#xff08;如开发、测试、生产&#xff09;之间共享配置&#xff0c;并且可以在不停止应用程序的情况下动态更新配置。 配置中心是统一管理各种应用配置的工具。它能够集中…

蓝桥杯真题讲解:异或和之和 (拆位、贡献法)

蓝桥杯真题讲解&#xff1a;异或和之和 &#xff08;拆位、贡献法&#xff09; 一、视频讲解二、正解代码 一、视频讲解 蓝桥杯真题讲解&#xff1a;异或和之和 &#xff08;拆位、贡献法&#xff09; 二、正解代码 //拆位考虑 #include<bits/stdc.h> #define endl &…

教你怎么写苹果群控系统!

在数字化时代&#xff0c;随着智能手机的普及和iOS系统的广泛应用&#xff0c;苹果设备的管理和控制变得日益重要&#xff0c;为了满足这一需求&#xff0c;苹果群控系统应运而生。 一、系统概述 苹果群控系统是一种能够对多台苹果设备进行集中管理和控制的软件系统。通过该系…

从GPT入门,到R语言基础与作图、回归模型分析、混合效应模型、多元统计分析及结构方程模型、Meta分析、随机森林模型及贝叶斯回归分析综合应用等专题及实战案例

目录 专题一 GPT及大语言模型简介及使用入门 专题二 GPT与R语言基础与作图&#xff08;ggplot2&#xff09; 专题三 GPT与R语言回归模型&#xff08;lm&glm&#xff09; 专题四 GPT与混合效应模型&#xff08;lmm&glmm&#xff09; 专题五 GPT与多元统计分析&…

鸿蒙Harmony应用开发—ArkTS声明式开发(基础手势:NavDestination)

作为子页面的根容器&#xff0c;用于显示Navigation的内容区。 说明&#xff1a; 该组件从API Version 9开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起始版本。 该组件从API Version 11开始默认支持安全区避让特性(默认值为&#xff1a;expandSaf…

【STM32】串口助手接受数据是乱码如何解决

第一步 首先判断自己使用的串口助手和工程配置的波特率是否相同&#xff0c;一般都是115200 第二步 如果不是上一条的问题&#xff0c;继续排查&#xff0c;检查时钟问题 打开工程&#xff0c;找到此文件(stm32f10x.h)的这个位置&#xff0c;如工程中未添加&#xff0c;可以从…

【组合递归回溯】【removeLast】Leetcode 39. 组合总和

【组合递归回溯】【removeLast】Leetcode 39. 组合总和 解法1 ---------------&#x1f388;&#x1f388;题目链接&#x1f388;&#x1f388;------------------- 解法1 如果是一个集合来求组合的话&#xff0c;就需要startIndex 例如&#xff1a;77.组合 (opens new windo…

python——By.XPATH

一、大部分元素没有id、name唯一标识&#xff0c;此时就需要通过xpath from selenuim import webdriver from selenuim.webdriver.common.by import Bydriver webdriver.Chrome() driver.maximize_window() driver.get(http://xxx) time.sleep(3)# 通过By.XPATH找到唯一页面元…

WorkPlus移动应用平台,完美的移动化办公体验

在移动办公成为企业工作的主流趋势下&#xff0c;高效的移动应用平台对于提升工作效率和协作能力至关重要。WorkPlus以其卓越的性能和全面的功能&#xff0c;助力企业实现移动办公的新时代。 为何选择WorkPlus作为移动应用平台的新选择&#xff1f;首先&#xff0c;WorkPlus提供…

【SpringCloud微服务全家桶学习笔记-GateWay网关(微服务入口)】

Gateway服务网关 API网关为微服务架构中的服务提供了统一的访问入口&#xff0c;客户端通过API网关访问相关服务。API网关的定义类似于设计模式中的门面模式&#xff0c;它相当于整个微服务架构中的门面&#xff0c;所有客户端的访问都通过它来进行路由及过滤。它实现了请求路…

Postman接口测试基本操作(全)

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 关注公众号【互联网杂货铺】&#xff0c;回复 1 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 Postman-获取验证码 需求&#xff1a;使用Postman访问验证码接…

LAMP 架构

LAMP和LNMP区别: 1、架构上&#xff1a; LAMPLinuxApacheMysqlPHP LNMPLinuxNginxMysqlPHP LAMP是LinuxApacheMysqlPHP的组合方式&#xff0c;bai用的是Linux&#xff1b; duLNMP是LinuxNginxMysqlPHP的组合方式&#xff0c;其特点是利用Nginx的快速zhi与轻量级&#xff0…

三月面了 6 家大厂,拿了 5 家 offer,进大厂好像也没有那么困难吧....

前言 二月底的时候因为换工作的缘故&#xff0c;陆续参加了华为、阿里巴巴、字节跳动、拼多多、百度、Paypal 的社招面试&#xff0c;除了字节跳动流程较长&#xff0c;我主动结束面试以外&#xff0c;其他的都顺利拿到了 Offer。 最近时间稍微宽裕点了&#xff0c;写个面经&…

vue3 动态路由及使用动态路由后刷新界面出现空白页或者404

最近编写vue3动态路由的功能遇到了一些问题&#xff0c;处理好了&#xff0c;总结出来&#xff0c;希望能帮助到你。正片开始 先写好本地缓存菜单的方法&#xff08;存储、删除、获取&#xff09; // utils/menu.jsconst getMenuList () > {return JSON.parse(localStorag…

掘根宝典之C++类型别名,关键字typedef,auto,decltype

类型别名 在C中&#xff0c;我们可以使用typedef关键字或using关键字来创建类型别名。下面是两种方式的示例&#xff1a; 使用typedef关键字创建类型别名&#xff1a; typedef int myInt; typedef float myFloat;myInt a;//等价int a; myFloat b;//等价float b; 使用using关…

4、Generator、class类、继承、Set、Map、Promise

一、生成器函数Generator 1、声明generator函数 function* 函数名() { }调用生成器函数 需要next()返回一个generator对象&#xff0c;对象的原型上有一个next(),调用返回对象{value:yield后面的值,done} function* fn() {console.log("我是生成器函数") } let it…

B端系统:漂亮就行。扯淡,漂亮仅占五分之一!

Hi&#xff0c;我是贝格前端工场&#xff0c;接触N多B端系统&#xff0c;也优化升级过N多。在这个过程中&#xff0c;仅仅美观是不够的&#xff0c;所以我拓展出来的B端系统五度评价指标&#xff0c;本篇着重讲易用性指标&#xff0c;欢迎老铁们评论点赞转发&#xff0c;有需求…

crossover玩不了qq游戏大厅怎么办 仍有五亿人坚持用QQ crossover玩游戏 Mac电脑玩QQ游戏

从1999年2月&#xff0c;QQ首个版本QICQ&#xff08;OPEN-ICQ&#xff09;上线。到2024年&#xff0c;靠着5亿月活用户&#xff0c;守住社交领域TOP2位置。你还记得QQ经典的铃声吗&#xff1f; 根据月狐数据2023年12月的统计&#xff0c;QQ月活跃账户数比微博和知乎加在一起还要…

安防视频监控汇聚平台EasyCVR使用RTMP推流出现异常的原因排查与解决

AI视频智能分析/视频监控管理平台EasyCVR能在复杂的网络环境中&#xff08;专网、内网、局域网、广域网、公网等&#xff09;&#xff0c;支持设备通过4G、5G、WIFI、有线等方式接入&#xff0c;并将设备进行统一集中接入与视频汇聚管理&#xff0c;经平台接入的视频流能实现多…