冒泡排序----深刻理解版本

前面虽然向大家介绍了冒泡排序,但是表达的不是很清楚,这次我带着更深刻的理解向大家介绍以下冒泡排序。

1.冒泡排序

冒泡排序其实是一种排序算法,通过数据之间的相互比较将一堆混乱的数据按照升序或者降序的顺序排列。

2.解题思路

解题思路依然不变,我们首先确立要比较的趟数,和一趟要比较的次数。

d46b094ca2e942bca08400760ab77b39.png

第一趟比较(红色部分)

76da688f65dc454c86e92443337bb85c.png

第二趟比较(绿色部分)

8c8e1e5abb4f4a9c8747caef26d9595b.png

第三趟比较(蓝色部分)

5f1ba9f5a4f54dedac48ba90e010b3e7.png

第四趟比较

11a3218ba26b4b218b6bdf6ea53a78f6.png

如上图所示,假设我们有五个数据要进行排序,我们要进行4趟排序,第一趟排序要进行比较4次,第二趟排序要比较3次,第三趟排序要比较2次,第四趟排序要进行比较1次。

所以我么得出结论:n个数据要进行排序时,要进行n-1趟排序。这里的趟数也是已经排序好数据的个数。 

代码实现

public class MySort {public static void Bubble(int[] arr){//确立趟数int i=0;for(i=0;i< arr.length-1;i++){//一趟要比较的次数for(int j=0;j< arr.length-1-i;j++){if(arr[j]>arr[j+1]){int tmp=arr[j];arr[j]=arr[j+1];arr[j+1]=tmp;}}}}public static void main(String[] args) {int[] arr=new int[]{10,8,6,9,3};System.out.print("排序前:");for(int j:arr){System.out.print(j+" ");}System.out.println();Bubble(arr);System.out.print("排序后:");for(int x:arr){System.out.print(x+" ");}}
}

这里我要介绍以下我更加深刻理解冒泡排序的一点,就是第二个for循环确定一趟要比较的次数,

其实上面是一种已经优化的版本了,未优化的版本循环条件为 j<arr.length-1在这种情况下,就意味着我们不论是进行哪一趟排序,在这一趟排序循环里面,它都会和所有的数据进行比较。不管之前经过排序就已经排序好的数据。

当我们写成 j<arr.length-1-i时,这里的i代表第几趟排序,经过i趟排序,就表示原本的数据中已经有i个数据已经排序好了,也就是说i也代表排序好的数据接着我们进行下一趟排序时,这一趟要排序的数据就不会和已经排序好的数据进行比较了,这要就提高的效率。

运行代码,如下图所示

3718e75557bb492cac28a4a543aa0897.png

但这还不是更好的优化版本。

先假设我们一开始的数据为10  3  6  8  9。

这时我们只进行一次比较就已经将数据排序好了,但是按照上面的写法,后面还是会进行后面比较的趟数,所以我们可以设计一个标志来确定在某一趟排序的时候,数据是否已经完全排序好了。

优化代码实现

public class MySort {public static void Bubble(int[] arr){//确立趟数int i=0;for(i=0;i< arr.length-1;i++){boolean flag=true;//标记//一趟要比较的次数for(int j=0;j< arr.length-1-i;j++){if(arr[j]>arr[j+1]){int tmp=arr[j];arr[j]=arr[j+1];arr[j+1]=tmp;flag=false;}}if(flag==true){break;}}}public static void main(String[] args) {int[] arr=new int[]{10,8,6,9,3};System.out.print("排序前:");for(int j:arr){System.out.print(j+" ");}System.out.println();Bubble(arr);System.out.print("排序后:");for(int x:arr){System.out.print(x+" ");}}
}

我们设置了一个flag变量,一开始为true,如果有 没排序好的数据就会进入循环,将flag的值变为false,进行完这一趟的排序,就又进行下一趟排序,然后在来确定有无 没排序好的数据,如果没有,就不会进入第二个循环,最终flag的值为true。这时我们根据flag的值为true,就知道此时数据已经完全排序好了。 

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

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

相关文章

Linux系统运维:修改docker容器与宿主机之间的端口映射,解决端口占用问题

目录 一、问题 二、docker端口映射 &#xff08;一&#xff09;docker端口映射定义 1、相关概念&#xff1a; 2、默认情况下&#xff0c;Docker容器会有一个端口映射&#xff1a; 3、端口范围&#xff1a; &#xff08;二&#xff09;配置相关 1、指定端口映射 2、随机…

【ArcGIS 脚本工具】格式化简单渲染图层或图层组

CAD加GIS是规划人的黄金搭档&#xff0c;不可偏废。 小编通常直接在ArcPro中加载CAD查看&#xff0c;这样可以保证CAD修改之后GIS能同步更新显示。 但是CAD在ArcPro中的显示多少有点水土不服。 比如湘源地块在ArcPro3.0中显示时会自动加上透明度&#xff0c;虽然这样可以看到…

LLM分布式训练---混合并行(2D 3D)

近年来&#xff0c;随着Transformer、MOE架构的提出&#xff0c;使得深度学习模型轻松突破上万亿规模参数&#xff0c;传统的单机单卡模式已经无法满足超大模型进行训练的要求。因此&#xff0c;我们需要基于单机多卡、甚至是多机多卡进行分布式大模型的训练。 而利用AI集群&a…

硬件知识积累 音频插座的了解,看音频插座的原理图来了解音频插座的引脚。

1. 音频接口 音频插座是一种用于连接音频信号线路的电子元件&#xff0c;常见于音频设备&#xff08;如音响、耳机、话筒等&#xff09;中。它的主要作用是将电子信号转化为声音信号&#xff0c;以满足人们对于音乐、电影、游戏等方面的需求。 根据插头形状的不同&#xff0c;音…

sql Server2015安装——参考的教程

1.sql Server安装包来自&#xff1a;https://mp.weixin.qq.com/s/Pe_YbWw_MgwjzzZhQWIYfA 2.需要的替换文件和补丁&#xff1a;https://blog.csdn.net/Auspicious_air/article/details/108315154 https://blog.csdn.net/m0_60477996/article/details/126748477 3.安装manger…

postgresql中控制符带来的数据错觉

简介 在数据库字符集中&#xff0c;由于数据质量的控制不够完善&#xff0c;每一个字符集都并不是所有字符的能看见&#xff0c;有些字符的展示可能会出现乱码&#xff0c;甚至出现不同字符展示成同样效果的可能&#xff0c;给开发人员造成分析错觉。 当数据库存入了控制符&am…

关于位操作符的实际应用<C语言>

前言 位操作符在C语言初学阶段相对其他操作符来说&#xff0c;是一种难度比较大的操作符&#xff0c;且运用较少的一类操作符&#xff0c;但是位操作符并不是“一无是处”&#xff0c;合理运用的位操作符&#xff0c;在某些场景下可以优化算法&#xff0c;提高代码的执行效率&a…

GRS认证的优点和缺点是什么?

GRS认证&#xff08;Global Recycled Standard&#xff09;的优点主要体现在以下几个方面&#xff1a; 环保性&#xff1a;GRS认证鼓励和保证产品中使用更多的回收材料&#xff0c;从而减少对原始资源的需求和开采&#xff0c;有助于降低环境负荷&#xff0c;促进资源的循环利用…

Python入门到精通,一个月就够了!前字节大佬超详细系统学习路线

毫无疑问&#xff0c;Python 是当下最火的编程语言之一。 对于许多未曾涉足计算机编程的领域「小白」来说&#xff0c;深入地掌握 Python 看似是一件十分困难的事。 感觉很迷茫&#xff1f;学了一段时间还是不入流&#xff1f;很大一部分原因是因为你没有一个完整的知识体系&…

python日常消费数据占比分析总结年消费方向

欢迎关注我👆,收藏下次不迷路┗|`O′|┛ 嗷~~ 目录 一.前言 整体消费情况 消费趋势 特定领域消费数据

大数据面试题 —— 数据仓库

目录 数据仓库是什么数据仓库和数据库的区别为什么要对数据仓库分层数仓分层&#xff0c;以及每一层的作用维度建模的三种模型范式建模、维度建模维度建模过程&#xff0c;如何确定这些维度 ***维度模型的各个维度之间是怎么聚合的聚合过程的数据倾斜怎么解决&#xff1f;数据质…

pyqt6的安装,使用-1

pyqt6安装的话&#xff0c;在自己所用的环境里安就可以&#xff0c;之前写有yolov5,yolov8的环境配置&#xff0c;python3.8的我安装就没有问题&#xff0c;打开anaconda&#xff0c;激活自己的环境 把这复制进去 pip install pyqt6 pip install pyqt6-tools 这个安装完了之后…