排序算法之冒泡排序篇

冒泡排序的思想:

是一个把元素从小到大排的一个算法思想

相邻的两个元素两两比较,大的那一个元素向后移,小的那个元素向前移

核心逻辑:

比较所有相邻的两个项,如果第一个比第二个大,就交换它们

从头开始:

第一轮排序时:每相邻的两个元素进行比较,

让大的元素排在后面,

让小的元素排在前面,

第一轮排序之后就让最大的元素排在了最后面,

一共要进行n-1轮的排序,即如果一共有n个元素,那么就要进行n-1轮的排序

视频实现冒泡排序

文字描述如上,以下是冒泡排序的视频全过程

冒泡排序全过程

代码实现冒泡排序

接下来我们进行代码的实现

用一个方法来实现这个冒泡排序

java 复制代码
public static void bubble(int[] arr){
	//外层循环的是一共要比较循环多少遍,即要进行多少轮的排序
	for(int i = 0;i < arr.length-1; i++){
		//内层循环的是每一轮循环一共要比较多少次
		for(int j = 0; i <arr.length -i-1; j++){
			if(arr[j] > arr[j+1]){
				//如果第一个元素大于第二个就交换
				int temp = arr[j];
				arr[j] = arr[j+1];
				arr[j+1] = temp;
			}
		}
	}
}

时间复杂度分析:

最好情况:

O(N):最好情况之下,数组完全是有序的,但是冒泡排序仍然需要进行一次循环

最坏情况:

O(N^2):最坏情况之下,数组是完全逆序的,冒泡排序需要进行(n-1)次循环

相关推荐
田梓燊37 分钟前
力扣:23.合并 K 个升序链表
算法·leetcode·链表
re林檎1 小时前
算法札记——4.27
算法
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
数据牧羊人的成长笔记2 小时前
逻辑回归与Softmax回归
算法·回归·逻辑回归
郑州光合科技余经理2 小时前
同城O2O海外版二次开发实战:从支付网关到配送算法
开发语言·前端·后端·算法·架构·uni-app·php
Mrlxl.cn4 小时前
计算机网络——网络层
c语言·数据结构·计算机网络·考研
d111111111d5 小时前
STM32-UART封装问题解析
笔记·stm32·单片机·嵌入式硬件·学习·算法
寒秋花开曾相惜5 小时前
(学习笔记)4.2 逻辑设计和硬件控制语言HCL(4.2.1 逻辑门&4.2.2 组合电路和HCL布尔表达式)
linux·网络·数据结构·笔记·学习·fpga开发
Jiangxl~6 小时前
IP数据云如何为不同行业提供精准IP查询与风险防控解决方案?
网络·网络协议·tcp/ip·算法·ai·ip·安全架构
李伟_Li慢慢7 小时前
wolfram详解山峦算法
前端·算法