#include <stdlib.h>
#include <stdio.h>
#include <iostream>
using namespace std;
typedef int element;
void merge(element *list,element *sorted,int i,int m,int n)
{
int j=m+1,k=i;
while(i<=m && j<=n){
if(list[i]<=list[j])
sorted[k++]=list[i++];
else
sorted[k++]=list[j++];
}
for(;i<=m;i++) sorted[k++]=list[i];
for(;j<=n;j++) sorted[k++]=list[j];
}
void merge_pass(element *list,element *sorted,int n,int length)
{
int i;
for(i=0;i<=n-2*length;i+=2*length)
merge(list,sorted,i,i+length-1,i+2*length-1);
if(i+length<n)
merge(list,sorted,i,i+length-1,n-1);
else
for(;i<n;i++) sorted[i]=list[i];
}
void merge_sort(element* list,int n)
{
int length=1;
element* sorted=new element[n];
while(length<n){
merge_pass(list,sorted,n,length);
length*=2;
merge_pass(sorted,list,n,length);
length*=2;
}
}
int main()
{
int a[]={2,3,4,2,1,2,9,10};
int len=sizeof(a)/sizeof(int);
merge_sort(a,len);
for(int i=0;i<len;i++) cout<<a[i]<<" ";
cout<<endl;
}
相关文章
- 计算机软考中级 知识点记忆——排序算法 冒泡排序-插入排序- 归并排序等 各种排序算法知识点整理
- AcWing - 归并排序(归排)
- 深入理解归并排序:分治艺术的经典实践
- 【排序算法】归并排序与快速排序:深入解析与比较
- 归并排序(Java实现)
- 排序算法--归并排序-优化建议
- 在排序模型方面,点评搜索也经历了业界比较普遍的迭代过程:从早期的线性模型LR,到引入自动二阶交叉特征的FM和FFM,到非线性树模型GBDT和GBDT+LR,到最近全面迁移至大规模深度学习排序模型。
- php基础排序算法 冒泡排序 选择排序 插入排序 归并排序 快速排序
- POJ 2299 Ultra-QuickSort 归并排序、二叉排序树,求逆序数
- 快排,归并和Shell排序