在java项目中实现归并排序的方法
短信预约 -IT技能 免费直播动态提醒
在java项目中实现归并排序的方法?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
归并排序算法:假设初始序列含有n个记录,首先将这n个记录看成n个有序的子序列,每个子序列长度为1,然后两两归并,得到n/2个长度为2(n为奇数的时候,最后一个序列的长度为1)的有序子序列。在此基础上,再对长度为2的有序子序列进行亮亮归并,得到若干个长度为4的有序子序列。如此重复,直到得到一个长度为n的有序序列为止。这种方法被称作是:2-路归并排序(基本操作是将待排序列中相邻的两个有序子序列合并成一个有序序列)。
算法实现代码如下:
package exp_sort;public class MergeSort { public static void Merge(int class="lazy" data-src_array[], int low, int high, int des_array[]) { int mid; int i, j, k; mid = (low + high) / 2; i = low; k = 0; j = mid + 1; // compare two list while (i <= mid && j <= high) { if (class="lazy" data-src_array[i] <= class="lazy" data-src_array[j]) { des_array[k] = class="lazy" data-src_array[i]; i = i + 1; } else { des_array[k] = class="lazy" data-src_array[j]; j = j + 1; } k = k + 1; } // if 1 have,cat while (i <= mid) { des_array[k] = class="lazy" data-src_array[i]; k = k + 1; i = i + 1; } while (j <= high) { des_array[k] = class="lazy" data-src_array[j]; k = k + 1; j = j + 1; } for (i = 0; i < k; i++) { class="lazy" data-src_array[low + i] = des_array[i]; } } public static void mergeSort(int class="lazy" data-src_array[], int low, int high, int des_array[]) { int mid; if (low < high) { mid = (low + high) / 2; mergeSort(class="lazy" data-src_array, low, mid, des_array); mergeSort(class="lazy" data-src_array, mid + 1, high, des_array); Merge(class="lazy" data-src_array, low, high, des_array); } } public static void main(String[] args) { // TODO Auto-generated method stub int array1[] = { 38, 62, 35, 77, 55, 14, 35, 98 }; int array2[] = new int[array1.length]; mergeSort(array1, 0, array1.length - 1, array2); System.out.println("\n----------after sort-------------"); for (int ii = 0; ii < array1.length; ii++) { System.out.print(array1[ii] + " "); } System.out.println("\n"); }}
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
在java项目中实现归并排序的方法
下载Word文档到电脑,方便收藏和打印~
下载Word文档
猜你喜欢
在java项目中实现归并排序的方法
在java项目中实现归并排序的方法?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。归并排序算法:假设初始序列含有n个记录,首先将这n个记录看成n个有序的子序列,每个子序列长度为1
2023-05-31
怎么在java 项目中使用归并排序算法
怎么在java 项目中使用归并排序算法?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。归并排序 归并排序,指的是将两个已经排序的序列合并成一个序列的操
2023-05-31
Java排序算法之归并排序简单实现
算法描述:对于给定的一组记录,首先将每两个相邻的长度为1的子序列进行归并,得到 n/2(向上取整)个长度为2或1的有序子序列,再将其两两归并,反复执行此过程,直到得到一个有序序列。package sorting;/** * 归并排序 * 平
2023-05-30
2024-04-02
java怎么实现归并排序算法
归并排序算法的实现步骤如下:1. 首先,实现一个归并操作函数。该函数将两个已排序的数组合并为一个新的已排序的数组。例如:```javapublic static void merge(int[] arr, int left, int mid
2023-08-15
Java 语言实现归并排序算法
【引言】 归并排序算法是一种高效且稳定的排序算法。它采用分治法的思想,将数组反复分割成两个子数组,直到每个子数组只有一个元素。然后将这些子数组逐个合并,最终得到排序完毕的数组。本文将使用Java语言实现归并排序算法,并详细讲解其核心思想和代
2023-08-30
2024-04-02
如何在python中实现归并排序
这期内容当中小编将会给大家带来有关如何在python中实现归并排序,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Python主要用来做什么Python主要应用于:1、Web开发;2、数据科学研究;3、网络
2023-06-14
Java的堆排序、快速排序、归并排序怎么实现
本文小编为大家详细介绍“Java的堆排序、快速排序、归并排序怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java的堆排序、快速排序、归并排序怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。堆排序
2023-06-26
2024-04-02
2024-04-02
如何在Java与Python实现一个归并排序算法
如何在Java与Python实现一个归并排序算法?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。归并排序里运用到算法里很重要的一个思想——分治法:将原问题分解为几个规模较小但
2023-05-31
2024-04-02
2024-04-02
怎么在Java项目中实现一个堆排序算法
怎么在Java项目中实现一个堆排序算法?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。堆是数据结构中的一种重要结构,了解“堆”的概念和操作,可以帮助我们快速地掌握堆排序。堆的
2023-05-31
在java项目中实现一个冒泡排算法的方法
这期内容当中小编将会给大家带来有关在java项目中实现一个冒泡排算法的方法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。一、算法原理比较相邻的元素。如果第一个比第二个大,就交换他们两个。对每一对相邻元素作
2023-05-31
Python实现的归并排序算法示例
本文实例讲述了Python实现的归并排序算法。分享给大家供大家参考,具体如下:
归并排序是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。
将已有序的子序列合并,得到完全
2022-06-04
如何在java项目中实现一个插入排序算法
如何在java项目中实现一个插入排序算法?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、基本概念 插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,
2023-05-31
利用java 怎么实现一个归并排序算法
本篇文章给大家分享的是有关利用java 怎么实现一个归并排序算法,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 归并排序算法,顾名思义,是一种先分再合的算法,其算法思想是将要排
2023-05-31
在java项目中实现一个树形选择排序
在java项目中实现一个树形选择排序?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。树形选择排序:又称锦标赛排序(Tournament Sort),是一种按照锦标赛的思想进行选择
2023-05-31