时间:2021-05-19
java 归并排序的实例详解
归并排序
归并排序,指的是将两个已经排序的序列合并成一个序列的操作。
归并操作的过程如下:
Java代码
/** * 归并排序 * * @param ts */ @SuppressWarnings("unchecked") public static <T extends Comparable<? super T>> void mergeSort(T[] ts) { // 辅助空间 T[] tempArray = (T[]) new Comparable[ts.length]; mergeSort(ts, tempArray, 0, ts.length - 1); } /** * 递归 */ private static <T extends Comparable<? super T>> void mergeSort(T[] ts, T[] tempArray, int left, int right) { if (left < right) { int center = (left + right) / 2; mergeSort(ts, tempArray, left, center); mergeSort(ts, tempArray, center + 1, right); // 左右合并 merge(ts, tempArray, left, center + 1, right); } } /** * 合并 */ private static <T extends Comparable<? super T>> void merge(T[] ts, T[] tempArray, int leftPos, int rightPos, int rightEnd) { int leftEnd = rightPos - 1; int temPos = leftPos; int numElements = rightEnd - leftPos + 1; while (leftPos <= leftEnd && rightPos <= rightEnd) //比较放到辅助空间 if (ts[leftPos].compareTo(ts[rightPos]) <= 0) tempArray[temPos++] = ts[leftPos++]; else tempArray[temPos++] = ts[rightPos++]; while (leftPos <= leftEnd) tempArray[temPos++] = ts[leftPos++]; while (rightPos <= rightEnd) tempArray[temPos++] = ts[rightPos++]; //考回原数组,此处最好用System.arraycopy优化 for (int i = 0; i < numElements; i++, rightEnd--) ts[rightEnd] = tempArray[rightEnd]; }复杂度:O(n log n)
比较操作的次数介于(n log n)/2和n log n - n + 1。 赋值操作的次数是(2nlogn)。
归并算法的空间复杂度为:Θ(n)
稳定性:稳定
扩展:
在java中,当执行一次泛型排序时,进行一次元比较可能是昂贵的,但是移动元素则是省时间的。归并排序使用所有的流行的排序算法中最少的比较次数,因此是使用java的通用排序算中的上好的选择。
以上使用java 使用归并排序的简单实例,有关java算法知识本站还有很多,大家可以搜索,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
java算法之归并排序详解一、思想归并排序:将一个数组排序,可以先(递归地)将它分成两半部份分别排序,然后将结果归并起来;二、概念归并:将两个有序的数组归并成一
C语言数据结构链表与归并排序实例详解归并排序适合于对链表进行原址排序,即只改变指针的连接方式,不交换链表结点的内容。归并排序的基本思想是分治法:先把一个链表分割
本文实例讲述了C++实现的归并排序算法。分享给大家供大家参考,具体如下:归并排序归并排序(MERGE-SORT)是建立在归并操作上的一种有效的排序算法。该算法是
本文实例讲述了Java排序算法总结之归并排序。分享给大家供大家参考。具体分析如下:归并操作(merge),也叫归并算法,指的是将两个已经排序的序列合并成一个序列
本文实例讲述了PHP排序算法之归并排序(MergingSort)。分享给大家供大家参考,具体如下:基本思想:归并排序:就是利用归并(合并)的思想实现的排序方法。