您的位置 首页 java

如何快速学会用Java实现排序算法,带实战案例讲解!

不稳定排序

选择排序

经过第一轮比较得到的最小的记录,与第一个记录的位置交换, 然后对不包括第一个记录以外的记录进行第二轮比较,得到的最小记录与第二个记录交换

时间复杂度 :O(n^2)

空间复杂度:O(1)

快速排序

对于一组给定的记录,每一趟排序后,将原来序列分为两部分,其中前一部分的所有记录均比后一部分的所有记录小,然后再依次对前后两部分记录进行快速排序

时间复杂度:O(nlogn) 最坏:O(n^2)

空间复杂度:O(nlogn)

小编整理了一份 java 学习资料,私信回复【01】,获取源码。

快速排序:

对于一组给定的记录,每一趟排序后,将原来序列分为两部分,其中前一部分的所有记录均比后一部分的所有记录小,然后再依次对前后两部分记录进行快速排序

时间复杂度:O(nlogn) 最坏:O(n^2)

空间复杂度:O(nlogn)

堆排序: 完全二叉树

将二叉树调整为大顶堆,然后将堆的最后一个元素与堆顶元素(即二叉树的根结点)进行交换后,堆的最后一个元素即为最大记录;接着将前n-1个元素调整为大顶堆,再将堆顶元素与当前堆的最后一个元素进行交换后得到次大的记录重复该过程直到调整的堆中只剩一个元素为止,该元素即为最小记录,此时可得到一个有序序列

时间复杂度:O(nlogn)

空间复杂度:O(1)

稳定排序

直接插入排序

第一个记录可以看作是自成一个有序序列,其余记录称为无序序列。 接着从第二个记录开始,按照记录的大小依次将当前处理的记录插入之前的有序序列中,直到最后一个记录插入到有序序列中为止

时间复杂度:O(n^2)

空间复杂度:O(1)

冒泡排序

从第一个记录开始依次对相邻的两个记录进行比较,当前面的记录大于后面的记录时,交换位置,进行一轮比较和换位后,n个记录中最大的记录将位于第n位,然后对前面的n-1个记录进行第二轮比较,重复该过程直到进行比较的记录只剩下一个为止

时间复杂度:O(n^2)

空间复杂度:O(1)

归并排序 :归:递归,并:分开的数据有序合并

将每两个相邻的长度为1的子序列进行归并,得到n/2个长度为2或1的有序子数列,再将两两归并,反复执行此过程,直到得到一个有序序列

时间复杂度:O(nlogn)

空间复杂度:O(n)

声明:本文内容来源于网络,如有侵权请联系删除

文章来源:智云一二三科技

文章标题:如何快速学会用Java实现排序算法,带实战案例讲解!

文章地址:https://www.zhihuclub.com/180881.shtml

关于作者: 智云科技

热门文章

网站地图