当前位置:网站首页>【21天学习挑战赛】冒泡排序与插入排序
【21天学习挑战赛】冒泡排序与插入排序
2022-08-02 20:03:00 【小卢要刷力扣题】
冒泡排序
冒泡排序的英文Bubble Sort,是一种最基础的交换排序。之所以叫做冒泡排序,因为每一个元素都可以像小气泡一样,根据自身大小一点一点向数组的一侧移动。
冒泡排序的步骤
比较相邻的元素。如果第一个比第二个大,就交换他们两个。
对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。这步做完后,最后的元素会是最大的数。
针对所有的元素重复以上的步骤,除了最后一个。
持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。
代码
public static void bubbleSort(int[] arr) {
if (arr == null || arr.length < 2) {
return;
}
// 0 ~ N-1
// 0 ~ N-2
// 0 ~ N-3
for (int e = arr.length - 1; e > 0; e--) {
// 0 ~ e
for (int i = 0; i < e; i++) {
if (arr[i] > arr[i + 1]) {
swap(arr, i, i + 1);
}
}
}
}
// 交换arr的i和j位置上的值
public static void swap(int[] arr, int i, int j) {
arr[i] = arr[i] ^ arr[j];
arr[j] = arr[i] ^ arr[j];
arr[i] = arr[i] ^ arr[j];
}
时间复杂度分析
因为有比较和交换行为,最差的情况就是每个元素从头交换到尾
例如[9,8,7,6,5,4,3,2,1,0]
因此时间复杂度为O(n2)
插入排序
插入排序是一种最简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。
在生活中,最简单的例子就是扑克牌的排序了,
在排序扑克牌的时候,我们会把小的排插入到前面
只要会了如何排序扑克牌,那么就可以很快的理解插入排序了
代码
public static void insertionSort(int[] arr) {
if (arr == null || arr.length < 2) {
return;
}
// 不只1个数
for (int i = 1; i < arr.length; i++) {
// 0 ~ i 做到有序
for (int j = i - 1; j >= 0 && arr[j] > arr[j + 1]; j--) {
swap(arr, j, j + 1);
}
}
}
public static void swap(int[] arr, int i, int j) {
arr[i] = arr[i] ^ arr[j];
arr[j] = arr[i] ^ arr[j];
arr[i] = arr[i] ^ arr[j];
}
时间复杂度
最差情况为每次小的元素都要从最后插到最前面
例如[9,8,7,6,5,4,3,2,1]
因此时间复杂度为O(n2)
边栏推荐
- Fiddle设置接口数据用指定工具查看;Sublime Text设置json数据格式化转换
- Redis 5 种数据结构及对应使用场景
- GNN教程:图神经网络基础知识!
- 特拉维夫大学 | Efficient Long-Text Understanding with Short-Text Models(使用短文本模型进行高效的长文本理解)
- The time series database has been developed for 5 years. What problem does it need to solve?
- 力扣每日一题-第46天-344. 反转字符串
- 所谓武功再高也怕菜刀-分区、分库、分表和分布式的优劣
- 解析Collection接口中的常用的被实现子类重写的方法
- 【LeetCode】1374. 生成每种字符都是奇数个的字符串
- ALV概念讲解
猜你喜欢
随机推荐
[AnXun cup 2019] easy_web
Triacetin是什么化学材料
ALV report learning summary
OP analysis and design
PG 之 SQL执行计划
Lvm逻辑卷
如何解决图像分类中的类别不均衡问题?不妨试试分开学习表征和分类器
Geoserver+mysql+openlayers2
Parse common methods in the Collection interface that are overridden by subclasses
The so-called fighting skill again gao also afraid of the chopper - partition, depots, table, and the merits of the distributed
V - memo new instructions
软考 ----- UML设计与分析(下)
【LeetCode】622. 设计循环队列
Thread线程类基本使用(下)
Solve the docker mysql can't write Chinese
TPAMI2022 | TransCL:基于Transformer的压缩学习,更灵活更强大
接口测试常用工具及测试方法(入门篇)
LeetCode 622 设计循环队列[数组 队列] HERODING的LeetCode之路
Bena的生命周期
模板的进阶