常见的排序算法有哪些
发表于:2025-01-18 作者:千家信息网编辑
千家信息网最后更新 2025年01月18日,本篇内容介绍了"常见的排序算法有哪些"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!冒泡排序最常见的排
千家信息网最后更新 2025年01月18日常见的排序算法有哪些
本篇内容介绍了"常见的排序算法有哪些"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
冒泡排序
最常见的排序算法之一,每次比较相邻的两个元素,如果需要的话则交换位置。
看下面的动图一目了然。
代码实现:
public static int[] sort(int[] arr){ if (arr.length < 2){ return arr; } //定义一个标志位,主要考虑到已经排好序的数组,避免不必要的计算 boolean flag; for(int i=1;iarr[j+1]){ int temp = arr[j]; arr[j] = arr[j+1]; arr[j+1] = temp; flag = false; } } if (flag){ break; } } return arr; }
性能分析:
时间复杂度:O(n2)
空间复杂度:O(1)
算法稳定性:元素相等不会交换,是稳定的排序算法
选择排序
选择排序,每次循环需要找出数组中最小的元素,放在数组的最前面。
动画:
代码实现:
public static int[] sort(int[] arr) { if (arr.length < 2) { return arr; } int minIndex; for (int i = 0; i < arr.length - 1; i++) { minIndex = i; for (int j = i + 1; j < arr.length; j++) { if (arr[j] < arr[minIndex]) { minIndex = j; } } if (i != minIndex) { int temp = arr[minIndex]; arr[minIndex] = arr[i]; arr[i] = temp; } } return arr; }
性能分析:
时间复杂度:O(n2)
空间复杂度:O(1)
插入排序
它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。
动画:
代码实现:
public static int[] sort(int[] arr) { if (arr.length < 2) { return arr; } for (int i = 1; i < arr.length; i++) { int temp = arr[i]; int j = i; for (; j > 0; j--) { if (temp < arr[j - 1]) { //符合条件往后挪 arr[j] = arr[j - 1]; } else { //此处break不能省略,用来停止 j 的自减 break; } } arr[j] = temp; } return arr; }
上面这种写法容易直观也容易理解;如果你能理解上面的写法,那么可以进一步把if判断表达式进行提取:
public static int[] sort1(int[] arr) { if (arr.length < 2) { return arr; } for (int i = 1; i < arr.length; i++) { int temp = arr[i]; int j = i; for (; j > 0 && temp < arr[j - 1]; j--) { //符合条件往后挪 arr[j] = arr[j - 1]; } arr[j] = temp; } return arr; }
"常见的排序算法有哪些"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
排序
算法
复杂
复杂度
常见
代码
元素
数组
位置
内容
写法
动画
序列
性能
性能分析
时间
更多
条件
知识
空间
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
富士康软件开发的面试
威海网络安全宣传周
导入数据库dmp字符集
冬奥会2022年网络安全志愿者
更新域名解析服务器
数据库基本数据类型
俄罗斯软件开发专家
项目建设和网络安全同步推进
数据库技术与大数据应用作业
网络安全培训有哪些内容
比特币服务器谁维护
小微企业使用数据库
十堰校园网络安全
互联网网络安全态势
数据库分页查询编号的解释
大数据方向的软件开发
软件开发要不要钱
学软件开发必须去培训班吗
遵义市网络安全宣传周活动
数据库sql的record难吗
嘉定区网络技术转让价钱
数据库root创建外网
东莞软件开发学院
北京字节跳动网络技术公司简介
对于网络安全的展望未来
成都邮政储蓄软件开发中心
信息网络安全时代的
网络安全工程师日记
centos服务器版下载
徐州通用软件开发