每天学一点算法-归并排序算法
来源:互联网 发布:故宫淘宝官方微博 编辑:程序博客网 时间:2024/05/16 08:57
归并排序算法
定义
归并排序(Merge sort,台湾译作:合并排序)是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。
步骤
1.申请空间,使其大小为两个已经排序序列之和,该空间用来存放合并后的序列
2. 设定两个指针,最初位置分别为两个已经排序序列的起始位置
3. 比较两个指针所指向的元素,选择相对小的元素放入到合并空间,并移动指针到下一位置
4. 重复步骤 3 直到某一指针达到序列尾
5. 将另一序列剩下的所有元素直接复制到合并序列尾
时间复杂度
O(nlogn)
代码
package com.sprd.test.algorithm;/** * Copyright 2014 TJ SPREADTRUM TEST_AF All Right Reserved * * @author: hui.qian Created on 2014年11月27日 上午9:09:13 Description: */public class Mergesort {public int[] sort(int[] a, int[] b) {int[] merge = new int[a.length + b.length];int indexA = 0;int indexB = 0;int i = 0;while (indexA < a.length && indexB < b.length) {if (a[indexA] <= b[indexB]) {merge[i++] = a[indexA++];} else {merge[i++] = b[indexB++];}}if (indexA == a.length) {for (int j = indexB; indexB < b.length; indexB++) {merge[i++] = b[indexB];}} else {for (int j = indexA; indexA < a.length; indexA++) {merge[i++] = b[indexA];}}return merge;}public static void main(String[] args) {int[] sortA = { 1, 3, 5, 7, 9 };int[] sortB = { 2, 4, 6, 8, 10 };Mergesort sorter = new Mergesort();long start = System.currentTimeMillis();int[] sorted = sorter.sort(sortA, sortB);long end = System.currentTimeMillis();System.out.println("耗时 : " + (end - start));System.out.println("排序前 : ");print(sortA);print(sortB);System.out.println("排序后 : ");print(sorted);}public static void print(int[] datas) {for (int i = 0; i < datas.length; i++) {System.out.print(datas[i] + " ");}System.out.println("");}}
输出
耗时 : 0排序前 : 1 3 5 7 9 2 4 6 8 10 排序后 : 1 2 3 4 5 6 7 8 9 10
0 0
- 每天学一点算法-归并排序算法
- 每天学一点算法-快速排序算法
- 每天学一点算法-堆排序算法
- 每天学一点算法-选择排序算法
- 每天学一点算法
- 每天学一点算法-DFS
- 每天学一点算法-BFS
- 每天一种算法-归并排序
- 每天学一点算法-Dijkstra算法
- 每天学一点算法-SPFA算法
- 每天学一点算法-二分查找算法
- 每天学一点算法-线性查找算法
- 每天学一点算法-动态规划算法
- 算法重头学-归并排序
- 每天多一点算法-插入排序算法
- 【从头开始学算法】归并排序
- 每天学一点flash (41) 椭圆算法
- 排序算法-归并算法
- 7.4.1 用映射操作进行更新
- Spring中注解: @Transactional 事务处理
- 互联网大潮下 如何留住人才?
- 1001.Alphacode
- mysql ORDER BY,GROUP BY 和DISTINCT原理 及执行顺序
- 每天学一点算法-归并排序算法
- 以左下三角的形式输出杨辉三角形。
- Extjs Button控件的handler配置项和click事件
- 优化Linux下的内核TCP参数来提高服务器负载能力
- Android的4大组件
- 我理解的MySQL Double Write
- 详细解答Uva - 1368 - DNA Consensus String
- BitMap算法
- Android中的定时器AlarmManager