常用排序算法之冒泡排序 (C、Javascript实现)

2024-09-01 19:58

本文主要是介绍常用排序算法之冒泡排序 (C、Javascript实现),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.“冒泡”的由来

按照气泡在水中上浮的顺序进行模拟的一种算法,一般较大的气泡上浮越快,较小的气泡则在其后。

(介是由于浮力,别问我为什么 \(^o^)/~)

 

2.基本思想

每次比较两个相邻的元素,如果按照从大到小的顺序依次排序,一旦他们出现错误顺序,则将其相互置换。

 

3.算法流程(未优化)

假设有3个元素3,1,2,将这3个数按大到小的顺序进行排序,也就是说越往后的数越小 。

 0            1          2

 

351

 

    

第一轮比较,(第一个数与每一个数进行比较,找到错误顺序,将其与第一个数进行交换。)

首先,比较第一个(3)与第一个(3);

此时,不用进行交换顺序。

然后,比较第一个(3)与第二个数(5);

很显然,后一个数5比3大,出现错误顺序,因此交换两者的顺序。顺序如下图,

0         1       2

 

531

 

 

然后,将新排好序的第一个数(5)与第三个数(1)进行比较;

此时,不用进行交换顺序。(第一轮结束)

第二轮比较,(第二个数与每一个数进行比较,找到错误顺序,将其与第二个数进行交换。)

首先,比较第二个数(3)与第一个数(5);

此时,不用进行交换顺序。

然后,比较第二个数(3)与第二个数(3);

此时,不用进行交换顺序。

最后,比较第二个数(3)与第三个数(1);

此时,不用进行交换顺序。

第三轮比较,(第二个数与每一个数进行比较,找到错误顺序,将其与第二个数进行交换。)

 

首先,比较第三个数(1)与第一个数(5);

此时,不用进行交换顺序。

然后,比较第三个数(1)与第二个数(3);

此时,不用进行交换顺序。

最后,比较第三个数(1)与第三个数(1);

此时,不用进行交换顺序。

4.核心代码

 

for(i=0;i<N;i++){for(j=0;j<N;j++){
<span style="white-space:pre">		</span>if(a[i]>a[j]){<span style="white-space:pre">			</span>int temp = a[i];
<span style="white-space:pre">			</span>a[i]=a[j];<span style="white-space:pre">			</span>a[j]=temp;
<span style="white-space:pre">		</span>}}
}

 

 

 

5.代码优化

通过以上例子,是不是觉得每i轮数比较完之后,第i个数之前的数都是已经排好序的,我们只需要将i之后的数进行再排序,这样所用的时间将是原来算法的一半。1/2O(n2)

 

for(i=0;i<N;i++){for(j=i;j<N;j++){
<span style="white-space:pre">	</span> <span style="white-space:pre">	</span>if(a[i]>a[j]){
<span style="white-space:pre">			</span>int temp = a[i];
<span style="white-space:pre">		</span> <span style="white-space:pre">	</span>a[i]=a[j];
<span style="white-space:pre">		</span> <span style="white-space:pre">	</span>a[j]=temp;
<span style="white-space:pre">	</span> <span style="white-space:pre">	</span>}}
}

6.完整代码

 

 

#include <stdio.h>
#define N 5
int main(void){int a[N]={3,5,1,2,4};int i=0;printf("数组初始顺序如下:\n");for(;i<N;i++){printf("%-5d",a[i]);}printf("\n-------------------\n");int j;for(i=0;i<N;i++){for(j=i;j<N;j++){if(a[i]>a[j]){int temp = a[i];a[i]=a[j];a[j]=temp;}}}printf("\n数组排序后的顺序如下:\n");for(i=0;i<N;i++){printf("%-5d",a[i]);}return 0;} 


7.运行结果

 


 

此时,不用进行交换顺序。

这篇关于常用排序算法之冒泡排序 (C、Javascript实现)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1127905

相关文章

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.