冒泡排序实现以及优化

一,冒泡排序说明

冒泡排序是从第一个元素开始和后面一个元素进行判断是否满足左小右大,如果不满足就交换位置,再拿第二个和第三个进行上述操作一直到第n-1和第n个。

经过上述的一轮操作就可以把第一个最大值放到最右边,在进行n轮上述操作就可完成所有元素的排序

因此冒泡排序的时间复杂度稳定为O(n^2)

二,冒泡排序代码

//
// Created by 27893 on 2025/8/10.
//#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "BubbleSort.h"void BubbleSort(SortTable *table) {for (int i=0;i<table->length;i++) {for (int j=0;j<table->length-i-1;j++) {if (table->data[j].key>table->data[j+1].key) {swap(&table->data[j],&table->data[j+1]);}}}
}void swap(Element*a,Element*b) {Element*temp=malloc(sizeof(Element));memcpy(temp,a,sizeof(Element));memcpy(a,b,sizeof(Element));memcpy(b,temp,sizeof(Element));free(temp);
}

三,冒泡排序的优化

1.第一种

随着我们的交换可能不需要n轮就已经将所有元素排好序了,比如我们在对第一个最大值进行排序时就可以把所有元素排好序,就没必要进行第二轮了,我们就可以用一个变量来记录这轮内循环是否有过交换,若果没有就说明已经排好序了

void BubbleSort(SortTable *table) {for (int i=0;i<table->length;i++) {int isSorted=1;for (int j=0;j<table->length-i-1;j++) {if (table->data[j].key>table->data[j+1].key) {isSorted=0;swap(&table->data[j],&table->data[j+1]);}}if (isSorted) {break;}}
}

2.第二种

如下图假如经过第一轮排序,从65开始后面的元素就已经有序了,那么下轮排序就只需要循环到65为止后面的就不需要比较了

void BubbleSortV3(SortTable *table) {int newIndex=0;do {int n=table->length;for (int i=0;i<n-1;i++) {if (table->data[i].key>table->data[i+1].key) {swap(&table->data[i],&table->data[i+1]);newIndex=i+1;}}n=newIndex;}while (newIndex>0);
}

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

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

相关文章

水下管道巡检机器人cad【10张】三维图+设计说明书

摘 要 水下管道是水下油气管道的生命线&#xff0c;水下管道巡检机器人可以替代人工完成水下油气管道状态的实时监测和数据反馈&#xff0c;有助于工作人员对水下油气管道的运行情况实时掌握。 本文完成了水下管道巡检机器人的总体设计&#xff0c;采用三维设计软件Solidwor…

SQL(结构化查询语言)的四大核心分类

这张图展示了 SQL&#xff08;结构化查询语言&#xff09;的四大核心分类&#xff0c;分别对应不同的数据库操作场景。以下是逐类解析&#xff1a;1. 数据操作语言&#xff08;DML&#xff1a;Data Manipulation Language&#xff09;作用&#xff1a;用于操作数据库中的数据&a…

AI(1)-神经网络(正向传播与反向传播)

&#x1f34b;&#x1f34b;AI学习&#x1f34b;&#x1f34b;&#x1f525;系列专栏&#xff1a; &#x1f451;哲学语录: 用力所能及&#xff0c;改变世界。 &#x1f496;如果觉得博主的文章还不错的话&#xff0c;请点赞&#x1f44d;收藏⭐️留言&#x1f4dd;支持一下博主…

嵌入式Linux学习 - 数据结构6

五、哈希表1. 哈希算法将数据通过哈希算法映射成一个键值&#xff0c;存取都在同一位置实现数据的高效存储和查找将时间复杂度尽可能降低至O(1)2. 哈希碰撞多个数据通过哈希算法得到的键值相同&#xff0c;称为产生哈希碰撞3. 哈希表构建哈希表存放0-100之间的数据将0 - 100之间…

GitHub 趋势日报 (2025年08月07日)

&#x1f4ca; 由 TrendForge 系统生成 | &#x1f310; https://trendforge.devlive.org/ &#x1f310; 本日报中的项目描述已自动翻译为中文 &#x1f4c8; 今日获星趋势图 今日获星趋势图1894nautilus_trader354stagehand315openai-cookbook263sim242ollama230prisma154v…

android 使用openimagelib OpenImage 实现点击放大图片,浏览

在 Android 中使用 OpenImageLib(假设这是一个开源图片加载库,类似于 Glide 或 Picasso)实现 点击放大图片并浏览 的功能,通常需要结合 图片查看器库(如 PhotoView)和 图片加载库(如 OpenImageLib)。以下是完整的实现方案: 1. 添加依赖 (1) 添加 OpenImageLib 依赖 …

计算机视觉CS231n学习(4)

深度学习软件 &#xff08;这一部分去看tensorflow和pytorch的笔记&#xff09; &#xff08;见专栏&#xff09;tensorflow和pytorch区别 tensorflow&#xff0c;我们先构建显示的图&#xff0c;然后重复运行它 pytorch&#xff0c;我们每次做前向传播时&#xff0c;都构建一个…

【具身智能】具身智能的革命——人形机器人如何重塑人类日常生活

还在为高昂的AI开发成本发愁?这本书教你如何在个人电脑上引爆DeepSeek的澎湃算力! 2025年被誉为具身智能的元年,人形机器人技术迅猛发展,将深刻改变人类生活方式。本文从具身智能的核心概念入手,探讨人形机器人的硬件架构、感知系统、运动控制和决策算法等技术基础。结合…

Jira Service Management企业服务管理:IT、HR、法务、财务等部门如何落地现代企业服务管理理念与实践

Jira Service Management 服务管理方法Jira Service Management 服务管理方法将开发、IT运营和业务团队整合至一个统一平台&#xff0c;以实现更高效的协作。任何团队都能够快速响应业务变化&#xff0c;为客户和员工提供卓越体验。Jira Service Management 提供直观、经济高效…

软件开发 - danger 与 dangerous、warn 与 warning

danger 与 dangerous 1、danger词性&#xff1a;n.含义&#xff1a;指可能造成伤害或损失的情况或事物# 例词in 【danger】&#xff08;处于危险中&#xff09; out of 【danger】&#xff08;脱离危险&#xff09;# 例句After the surgery, the doctor said the patient was o…

为何毫米波需要采用不同的DPD方法?如何量化其值?

摘要 在5G新无线电技术标准中&#xff0c;除了sub-6 GHz频率外&#xff0c;还利用毫米波(mmWave)频率来提高吞吐量。毫米波频率的使用为大幅提高数据吞吐量带来了独特的机会&#xff0c;同时也带来了新的实施挑战。本文探讨sub-6 GHz和毫米波基站无线电之间的架构差异&#xff…

【数据结构入门】栈和队列的OJ题

目录 1. 有效的括号 分析&#xff1a; 代码&#xff1a; 2. 用队列实现栈 分析&#xff1a; 代码&#xff1a; 3. 用栈实现队列 分析&#xff1a; 代码&#xff1a; 4. 设计循环队列 思路&#xff1a; 代码&#xff1a; 定义循环队列结构体&#xff1a; 初始化结…

#Datawhale AI夏令营#第三期全球AI攻防挑战赛(AIGC技术-图像方向)

本次题目来源于Datawhale AI夏令营第三期全球AI攻防挑战赛图像生成赛道。首先看一下赛题背景和要求。1.赛题相关大赛背景随着大模型&#xff08;Deepseek、GPT、LLaMA等&#xff09;的爆发式应用&#xff0c;AI技术已深度融入金融、医疗、智能终端语音交互场等核心领域&#xf…

Compose笔记(四十二)--RangeSlider

这一节主要了解一下Compose中的RangeSlider&#xff0c;在Jetpack Compose中&#xff0c;RangeSlider是Material3库提供的双滑块范围选择控件&#xff0c;用于在一个连续区间内选择最小值和最大值。它能直观地设置一个区间范围&#xff0c;广泛应用于筛选、过滤等场景,简单总结…

window10本地运行datax与datax-web

搭建 dataX 前置条件 JDK(1.8以上&#xff0c;推荐1.8)Python(2或3都可以)Apache Maven 3.x (Compile DataX) 下载 datax 编译好的包 https://datax-opensource.oss-cn-hangzhou.aliyuncs.com/202309/datax.tar.gz 进入目录&#xff0c;使用 powershell 打开 执行解压命令…

PDF注释的加载和保存的实现

PDF注释功能文档 概述 本文档详细说明了PDF注释功能的实现&#xff0c;包括注释的加载和保存功能。该功能基于Android PDFBox库实现&#xff0c;支持Ink类型注释的读取和写入。 功能模块 1. 注释加载功能 (getAnnotation()) 功能描述 从PDF文件中加载已存在的注释&#xff0c;并…

Linux环境下实现简单TCP通信(c)

具体代码实现 server.c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <arpa/inet.h> #include <sys/socket.h>#define PORT 8080 #define BUFFER_SIZE 1024void handle_client(int client_s…

炫酷圆形按钮调色器

<!DOCTYPE html> <html lang"zh"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>圆形按钮颜色控制器</title><style>bod…

Vue 3 的编译时优化如何改写 DOM 操作规则

在现代前端开发中&#xff0c;框架级优化正悄然改变我们处理性能瓶颈的方式。与手动优化策略不同&#xff0c;Vue 3 的编译器在构建阶段就完成了关键性能改造&#xff0c;为 DOM 操作效率带来质的飞跃。一、虚拟DOM的隐藏成本虚拟DOM&#xff08;Virtual DOM&#xff09;通过内…

Angular初学者入门第二课——.ts、.d.ts、.state.ts的区别(精品)

初次接触 Angular 实际项目时&#xff0c;发现里边有很多不同后缀的文件&#xff0c;虽然没深入研究过&#xff0c;但根据其他编程语言的经验猜测这应该是通过后缀名来区分文件的作用。后来有时间研究了一下具体的细节和不同点&#xff0c;就有了今天这篇文章&#xff0c;这些知…