java排序之归并排序
2021/8/30 22:06:06
本文主要是介绍java排序之归并排序,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
归并排序
一、概念及其介绍
归并排序(Merge sort)是建立在归并操作上的一种有效、稳定的排序算法,该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为二路归并。
二、适用说明
当有 n 个记录时,需进行 logn 轮归并排序,每一轮归并,其比较次数不超过 n,元素移动次数都是 n,因此,归并排序的时间复杂度为 O(nlogn)。归并排序时需要和待排序记录个数相等的存储空间,所以空间复杂度为 O(n)。
归并排序适用于数据量大,并且对稳定性有要求的场景。
class Solution { public int[] sortArray(int[] nums) { int[] result = new int[nums.length]; sort(nums, 0, nums.length-1, result); return result; } public void sort(int [] nums, int l, int r, int [] result) { if(l>=r) { return; } int mid = (l + r) / 2; sort(nums, l, mid, result); sort(nums, mid + 1, r, result); merge(nums, l, r, mid, result); } public void merge(int [] nums, int l, int r, int mid, int [] result) { int i = l; int j = mid + 1; int k; for(k = l;k<= r;k++) { if(i>mid) { result[k] = nums[j]; j++; } else if(j>r) { result[k] = nums[i]; i++; } else if(nums[i] < nums[j]) { result[k] = nums[i]; i++; } else { result[k] = nums[j]; j++; } } for(int p = l; p<= r; p++) { nums[p] = result[p]; } } }
注意最后:
for(int p = l; p<= r; p++) { nums[p] = result[p]; }
需要将排序后的拷贝到原数组中,这样才能满足后面的递归合并的是两个已经排好序的数组。
参考:https://www.runoob.com/data-structures/merge-sort.html
这篇关于java排序之归并排序的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-12百万架构师第十五课:源码分析:Spring 源码分析:SpringMVC核心原理及源码分析|JavaGuide
- 2025-01-11有哪些好用的家政团队管理工具?
- 2025-01-11营销人必看的GTM五个指标
- 2025-01-11办公软件在直播电商前期筹划中的应用与推荐
- 2025-01-11提升组织效率:上级管理者如何优化跨部门任务分配
- 2025-01-11酒店精细化运营背后的协同工具支持
- 2025-01-11跨境电商选品全攻略:工具使用、市场数据与选品策略
- 2025-01-11数据驱动酒店管理:在线工具的核心价值解析
- 2025-01-11cursor试用出现:Too many free trial accounts used on this machine 的解决方法
- 2025-01-11百万架构师第十四课:源码分析:Spring 源码分析:深入分析IOC那些鲜为人知的细节|JavaGuide