排序算法THREE:归并排序MergeSort
/**
*归并排序思路:分治法思想 O(nlogn)
* 把数组一分为二,二分为四
* 四和为二,二和为一
*
*/
/**
* 归并排序主方法
*@params 待排序的数组
*@params 初始位置
*@params 最终位置
*/
public class MergeSort
{
public static void mergeSort(int[] resouceArr, int begin , int end )
{
if ( begin < end )
{
int middle = ( begin + end ) / 2 ;
mergeSort( resouceArr , begin , middle );
mergeSort( resouceArr , middle + 1 , end );
_merge( resouceArr , begin , middle , end );
}
}
/**
*合并两个已经排好序数组的方法
*由mergeSort()调用,定义为private,命名以下划线开头
*/
private static void _merge(int[] arr , int begin , int middle , int end )
{
//获得左数组大小,右数组大小
int leftArrLength = middle - begin + 1 ;
int rightArrLength = end - middle ;
//申请空间
int[] leftArr = new int[leftArrLength + 1];
int[] rightArr = new int[rightArrLength + 1];
//初始化数组的值(把原数组的值一个一个复制quickArr到新数组中)
for( int i = 0 ; i < leftArrLength ; i++)
{
leftArr[i] = arr[begin + i] ;
}
for( int j = 0 ; j < rightArrLength ; j++)
{
rightArr[j] = arr[middle + j + 1] ;
}
//哨兵,放在最后
leftArr[leftArrLength] = 65536 ;
rightArr[rightArrLength] = 65536 ;
int i = 0 ;
int j = 0 ;
for(int k = begin ; k <= end ; k++ )
{
if( leftArr[i] <= rightArr[j] )
{
arr[k] = leftArr[i] ;
i = i + 1 ;
}
else
{
arr[k] = rightArr[j];
j = j + 1 ;
}
}
}
}
排序算法THREE:归并排序MergeSort的更多相关文章
- Java常见排序算法之归并排序
在学习算法的过程中,我们难免会接触很多和排序相关的算法.总而言之,对于任何编程人员来说,基本的排序算法是必须要掌握的. 从今天开始,我们将要进行基本的排序算法的讲解.Are you ready?Let ...
- 排序算法之归并排序(Mergesort)解析
转自:http://www.cnblogs.com/ayqy/p/4050452.html 一.归并排序的优缺点(pros and cons) 耗费心思来理解它,总要有个理由吧: 归并排序的效率达 ...
- 【排序算法】归并排序算法 Java实现
归并排序是建立在归并操作上的一种有效的排序算法.该算法是采用分治法(Divide and Conquer)的一个非常典型的应用. 基本思想 可以将一组数组分成A,B两组 依次类推,当分出来的小组只有一 ...
- 【DS】排序算法之归并排序(Merge Sort)
一.算法思想 归并排序是建立在归并操作上的一种有效的排序算法.该算法是采用分治法的一个非常典型的应用,指的是将两个已经排序的序列合并成一个序列的操作.其归并思想如下: 1)申请空间,使其大小为两个已经 ...
- 我的Java开发学习之旅------>Java经典排序算法之归并排序
一.归并排序 归并排序是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide and Conquer)的一个非常典型的应用.将已有序的子序列合并,得到完全有序的序列:即先使每个子序列 ...
- 我的Java开发学习之旅------>Java经典排序算法之归并排序
一.归并排序 归并排序是建立在归并操作上的一种有效的排序算法,该算法是採用分治法(Divide and Conquer)的一个很典型的应用.将已有序的子序列合并,得到全然有序的序列.即先使每一个子序列 ...
- 排序算法——QuickSort、MergeSort、HeapSort(C++实现)
快速排序QuickSort template <class Item> void quickSort (Item a[], int l, int r) { if (r<=l) ret ...
- C++编程练习(15)----“排序算法 之 归并排序“
归并排序 归并排序(Merging Sort)的原理: 假设初始序列含有 n 个记录,则可以看成是 n 个有序的子序列,每个子序列的长度为1,然后两两归并,得到 [n/2] ([ x ] 表示不小于 ...
- 数据结构与算法之PHP排序算法(归并排序)
一.基本思想 归并排序算法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,使每个子序列有序,再将已有序的子序列合并,得到完全有序的序列.该算法是采用分治法(Divid ...
随机推荐
- 理解 traits
1.为什么使用traits? 考虑下面的需求,实现一个方法Advance(iter,n),接收一个迭代器iter和移动距离n,将iter向前移动n个距离. 分析,因为存在不同类型的迭代器,做同一件事情 ...
- Codeforces Round #200 (Div. 1) B. Alternating Current 栈
B. Alternating Current Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/343 ...
- android学习日记24--Android 菜单开发
菜单是任何应用程序必不可少的一项.按下Menu键或者长按某个View就会弹出相应菜单,当然前提是应用程序有实现菜单功能. Android平台下的菜单有:Options Menu(选项菜单).Subme ...
- C#_Ajax分页MVCPager
UCJqOrderList @model PagedList<Order> <div id="dvOrders"> <table width=&quo ...
- SOAP 及其安全控制--转载
原文地址:http://my.oschina.net/huangyong/blog/287791 目录[-] 1. 基于用户令牌的身份认证 2. 基于数字签名的身份认证 3. SOAP 消息的加密与解 ...
- Redirect
Redirect To use this Class, add the following to the top of the file. use Redirect; Redirect::to($pa ...
- Forms and actions
Forms and actions Adding new albums We can now code up the functionality to add new albums. There ar ...
- Android-Opencv开发(一)配置环境
先去官网下载android-opencv http://opencv.org/.
- PHP 有关上传图片时返回HTTP 500错误
1. 检查PHP GD 扩展库是否开启或者安装 在Ubuntu server中,在php -m 之后,未看到gd扩展,所以需要安装gd,然后重启apache2 sudo apt-get install ...
- Burosuite抓包Sqlmap学习Sql注入
在sqlmap中加入--proyxy参数: --proxy "http://127.0.0.1:8080" 如下图所示: 回车以后sqlmap会自动抓到数据包: 我们选择向前(fo ...