C语言算法--冒泡排序

news2024/11/24 11:31:13

C语言算法–冒泡排序

1-什么是冒泡排序

冒泡排序是一种简单的排序算法,它通过比较相邻元素的大小,并根据需要交换它们的位置来排序数据。它的名称来自于越小的元素会慢慢“冒泡”到数组的开头。

冒泡排序的基本思想是从数组的第一个元素开始,依次比较相邻的两个元素的大小,并根据需要进行交换,使较大的元素逐渐向数组的末尾移动。在一次遍历中,最大的元素会被交换到数组的最后一个位置。然后,再进行下一次遍历,但这次只需比较到倒数第二个元素,依次类推。每次遍历都会将当前未排序的最大元素放置到正确的位置。

如下图(图片来源于图解算法使用C语言):

从上面我们可以看到,第一次先对55和23进行比较,如果其中的一个大于另一个则进行互换,假设55号大于23号中的元素。然后在接着对55号和87号进行比较,就这样一直比较下去,直到完成确定完整的为止。

2-冒泡排序的优点

  1. 简单易懂:冒泡排序的实现逻辑相对简单,容易理解和实现。它只需要使用基本的比较和交换操作就可以完成排序。
  2. 原地排序:冒泡排序是一种原地排序算法,不需要额外的空间来存储排序结果。它只需要在原始数组上进行元素的比较和交换操作。
  3. 稳定性:冒泡排序是一种稳定的排序算法,即相等元素的相对顺序在排序前后保持不变。只有当两个相邻元素进行交换时才会改变它们的相对顺序。
  4. 适用于小规模数据:由于冒泡排序的时间复杂度为O(n^2),在数据规模较小的情况下,冒泡排序的性能还是可以接受的。对于小规模的数据集,冒泡排序可能比其他复杂的排序算法更快。

3- 冒泡排序的缺点

  1. 时间复杂度高:冒泡排序的时间复杂度是O(n^2),其中n是待排序元素的个数。这意味着随着数据规模的增大,排序所需的比较和交换操作的次数会成平方倍增长。对于大规模数据集,冒泡排序的性能较差。
  2. 低效的性能:由于冒泡排序的特性,它在实际应用中的性能往往不如其他高效的排序算法。冒泡排序需要多次迭代才能将最大(或最小)元素移动到正确的位置,这可能导致大量的不必要比较和交换操作。
  3. 不适合大规模数据:由于冒泡排序的复杂度较高,它在处理大规模数据时效率较低。当数据集很大时,冒泡排序的执行时间可能会非常长,无法满足实时性要求。
  4. 缺乏适应性:冒泡排序的算法逻辑是通过相邻元素的比较和交换来逐步将较大(或较小)的元素“冒泡”到数组的末尾。这意味着即使在部分已经有序的情况下,冒泡排序仍然需要进行完整的比较和交换操作,无法充分利用已排序的部分。

4-冒泡排序可以应用哪些场景

  1. 小规模数据集:冒泡排序适用于处理小规模数据集,其中元素数量相对较少。在这种情况下,冒泡排序的性能可以接受,并且实现起来简单。
  2. 部分有序的数据:如果待排序的数据集已经部分有序,即只有少量元素需要进行排序,而其他元素已经有序,那么冒泡排序的性能会相对较好。由于冒泡排序会在每一轮迭代中扫描整个数组,但对于已经有序的部分,它可以快速跳过,减少不必要的比较和交换操作。
  3. 教育和理论研究:冒泡排序作为一种经典的排序算法,可以用于教育目的或理论研究中。它的实现简单,易于理解和教授。通过实现和分析冒泡排序,可以帮助学习者理解排序算法的基本原理和算法复杂度分析。

5-举例

#include <stdio.h>

void bubbleSort(int arr[], int size)
{
    for (int i = 0; i < size - 1; i++)
    {
        for (int j = 0; j < size - i - 1; j++)
        {
            if (arr[j] > arr[j + 1])
            {
                // 交换相邻元素
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}

int main()
{
    int arr[] = {5, 2, 8, 12, 1, 6};
    int size = sizeof(arr) / sizeof(arr[0]);

    printf("原始数组:");
    for (int i = 0; i < size; i++)
    {
        printf("%d ", arr[i]);
    }

    bubbleSort(arr, size);

    printf("\n排序后的数组:");
    for (int i = 0; i < size; i++)
    {
        printf("%d ", arr[i]);
    }

    return 0;
}

运行结果:

#include <stdio.h>

// 定义结构体
typedef struct
{
    int value;

} Element;

// 定义枚举类型
typedef enum
{
    ASCENDING,
    DESCENDING
} SortOrder;

// 冒泡排序函数
void bubbleSort(Element arr[], int size, SortOrder sortOrder)
{
    int i, j;
    Element temp;

    for (i = 0; i < size - 1; i++)
    {
        for (j = 0; j < size - i - 1; j++)
        {
            // 根据排序顺序进行比较
            if ((sortOrder == ASCENDING && arr[j].value > arr[j + 1].value) ||
                (sortOrder == DESCENDING && arr[j].value < arr[j + 1].value))
            {
                // 交换元素
                temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}

int main()
{
    Element arr[] =
    {
        {5},
        {2},
        {8},
        {1},
        {9}
        };
    int size = sizeof(arr) / sizeof(Element);
    int i;

    printf("原始数组: ");
    for (i = 0; i < size; i++)
    {
        printf("%d ", arr[i].value);
    }
    printf("\n");

    // 升序排序
    bubbleSort(arr, size, ASCENDING);

    printf("排序数组(升序): ");
    for (i = 0; i < size; i++)
    {
        printf("%d ", arr[i].value);
    }
    printf("\n");

    // 降序排序
    bubbleSort(arr, size, DESCENDING);

    printf("排序数组(降序): ");
    for (i = 0; i < size; i++)
    {
        printf("%d ", arr[i].value);
    }
    printf("\n");

    return 0;
}

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

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

相关文章

【黑马笔记】web app项目初始化

文章目录 0. 工程介绍1. 使用模版初始化1.1 选择模版1.2 补充文件 2. 使用空项目初始化2.1 新建maven项目&#xff0c;直接新建2.2 补充文件2.2.1 补充packaging形式&#xff1a;war2.2.2 借助Facets自动补齐 0. 工程介绍 打包方式 新建maven项目&#xff0c;使用<packing&…

数据结构总结1:了解数据结构、时间复杂度、空间复杂度

后续可能会有补充和更改 目录 一、数据结构 1.算法介绍 二、时间复杂度、空间复杂度 三、练习 1.时间复杂度 2.空间复杂度 一、数据结构 数据结构是计算机存储、组织数据的方式&#xff0c;指相互之间存在一种或多种特定关系的数据元素的集合。 数据结构和数据库的区…

Jmeter测试POST请求

Jmeter测试POST请求 1、添加http请求 线程组->取样器->http请求 参数说明&#xff1a; 协议&#xff1a;http 服务器&#xff1a;10.1.1.26&#xff08;也就是ip地址&#xff09; 端口&#xff1a;8081 方法&#xff1a;POST 路径&#xff1a;例如&#xff…

滴滴 Java 一面面经

目录 1.了解Java集合嘛&#xff0c;详细说一下Map&#xff1f;2.为什么HashTable线程安全却不常用&#xff1f;3.HashMap不是线程安全&#xff0c;多线程下会出现什么问题&#xff1f;4.什么办法能解决HashMap线程不安全的问题呢5.ConcurrentHashmap是怎么实现的&#xff1f;6.…

ALOHA 开源机械臂(Viper 300 Widow X 250 6DOF机械臂 操作系统)第三部分

详情链接&#xff1a;https://tonyzhaozh.github.io/aloha/ Learning Fine-Grained Bimanual Manipulation with Low-Cost Hardware 用低成本硬件学习细粒度双手操作 Tony Zhao Vikash Kumar Sergey Levine Chelsea Finn Stanford University UC Berkeley Meta 斯坦福大学…

分布式锁解决方案_Zookeeper分布式锁原理

通过召zk实现分布式锁可靠性时最高的 公平锁和可重入锁的原理 取水秩序&#xff1a; &#xff08;1&#xff09;取水之前&#xff0c;先取号&#xff1b; &#xff08;2&#xff09;号排在前面的&#xff0c;就可以先取水&#xff1b; &#xff08;3&#xff09;先到的排在…

Go语言的学习【1】基础语法之前的准备事项

目录 什么是云原生学习方法go语言的IDE配置之VScode写go代码要注意的事情一些基本命令基础语法Go 语言原生自带测试Go vetPrint-format 错误&#xff0c;检查类型不匹配的printBoolean 错误&#xff0c;检查一直为 true、false 或者冗余的表达式Range 循环&#xff0c;比如如下…

ThingsBoard部署tb-gateway并配置OPCUA

1、安装 我实在自己的虚拟机上安装,使用官方Docker的安装方式 docker run -it -v ~/.tb-gateway/logs:/thingsboard_gateway/logs -v ~/.tb-gateway/extensions:/thingsboard_gateway/extensions -v ~/.tb-gateway/config:/thingsboard_gateway/config --name tb-gateway --…

《安富莱嵌入式周报》第312期:开源磁场照相机,仿生神经元PCB,开源无线耳机,手机系统PalmOS移植到各种单片机,开放系统组装协议OSAP

周报汇总地址&#xff1a;嵌入式周报 - uCOS & uCGUI & emWin & embOS & TouchGFX & ThreadX - 硬汉嵌入式论坛 - Powered by Discuz! 更新一期视频教程&#xff1a; BSP视频教程第26期&#xff1a;CAN/CANFD/CANopen专题&#xff0c;CANFD整个运行机制精…

PyTorch RNN的原理及其手写复现。

PyTorch RNN的原理及其手写复现。 记忆单元(考虑过去的信息)分类包括&#xff1a;1.RNN 2.GRU 3.LSTM模型类别&#xff1a;1.单向循环(左到右) 2.双向循环&#xff08;考虑未来信息&#xff09; 3.多层单向或双向循环优缺点应用场景具体公式 代码实现 记忆单元(考虑过去的信息)…

网络安全合规-数据安全评估

目前&#xff0c;我国在数据管理领域&#xff0c;已经正式出台的国家标准有《数据管理能力成熟度评估模型&#xff08;GB/T 36073-2018&#xff09;》&#xff08;DCMM&#xff09;&#xff0c;在数据安全检测评估、认证领域的标准有《数据安全能力成熟度模型&#xff08;GB/T …

实现取关和关注功能

将关注过的用户id存如数据库中 //关注或者取关 Override public Result follow(Long id, Boolean flag) { //1.获取当前登录用户的id UserDTO user UserHolder.getUser(); if(usernull){ return Result.fail("请先登录"); } Long userId user.getId(); //2.判断是关…

vue3+antDesignVue前端纯导出

效果 <a-buttonsize"default"style"margin-left: 10px"click"exportData">导出</a-button>1.下载所需依赖 npm install xlsx --save npm install file-saver --save<script setup> import { reactive, ref } from "vue…

SpringBoot——多环境开发

简单介绍&#xff1a; 在我们的开发过程中&#xff0c;我们的程序开发分为几个基本的阶段&#xff0c;比如开发阶段&#xff0c;调试阶段&#xff0c;运行阶段&#xff0c;在不同的阶段可能需要有不同的配置文件去对我们的项目做配置&#xff0c;那么要如何在不同的环境中配置…

C语言:数组定义方式

一、数组简介 <1>前言 大家首先来思考一个问题&#xff0c;若是我们想要定义两个变量&#xff0c;求这两个数的平均数&#xff0c;该怎么求呢&#xff1f; 例如&#xff1a;int a 10,b 20 int average (a b) / 2; 上面的公式&#xff0c;我相信大家应该很快就能够求出…

牛奶蛋白过敏VS乳糖不耐受,看完这篇终于分清了

乳糖不耐受 乳糖不耐症的主要表现为一些胃肠道症状&#xff0c;有腹部紧张、肠鸣、腹痛、排气和腹泻等症状。如出现这些症状都是乳糖不耐受症的表现之一&#xff0c;但患有乳糖不耐的个体症状差异很大&#xff0c;而严重的乳糖不耐受多于摄入一定量乳糖后30min至数小时内发生。…

Python安装教程2023(小白专用)已验证

第一次接触Python&#xff1f;下面从一个完全不懂的Python 的小白来安装Python 等一系列工作的记录&#xff0c;并且遇到的问题也会写出&#xff0c;让完全不懂的小白也可上手安装&#xff0c;并且完成第一个Hello world代码。 [Python 安装] 目前&#xff0c;Python有两个版本…

【手机建站】Android Termux+cpolar内网穿透,搭建外网可以访问的网站

文章目录 概述1.搭建apache2.安装cpolar内网穿透3.公网访问配置4.固定公网地址5.添加站点 概述 Termux是一个Android终端仿真应用程序&#xff0c;用于在 Android 手机上搭建一个完整的Linux 环境&#xff0c;能够实现Linux下的许多基本操作&#xff0c;不需要root权限Termux就…

Word怎么转换成PDF免费?分享适合你的Word转PDF方法

随着数字化时代的到来&#xff0c;将文件转换为PDF格式已经成为一个常见的需求。PDF文件格式的广泛应用使其在各个领域都非常重要&#xff0c;而Word文档则是最常见的文件类型之一。因此&#xff0c;将Word转换为PDF的方法备受关注。在下面&#xff0c;我将分享一种适合任何人使…

基于ARIMA-CNN-LSTM预测模型研究(Python代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…