C++归并排序算法详解

一.算法简介

        归并排序算法的平均时间复杂度是O(nlogn),归并算法的实现就是通过分冶法,将一个待排序列分成一个个小的序列,然后对这些小的序列进行排序,然后进行合并,合并的时候也会进行排序,这样,从整体拆成小块,再从小块合成整体的一个过程。

二.实现过程

        1)拆分待排序列

        2)进行排序合并

给大家写了一个简单的过程以便大家理解。

C++归并排序算法详解_第1张图片

 这基本就是归并排序的实现原理了,那么代码是怎么实现的呢,下面给大家展示下代码实现。

//时间复杂度是nlogn
#include 
 
using namespace std;
 
void Merge(int a[],int s,int mid,int e,int tmp[]);//归并
void Merge_Sort(int a[],int s,int e,int tmp[]);//有序
 
int main(){
    int a[1000],tmp[1000];
    int n;
    cin >> n; 
    for(int i=0;i> a[i];
    Merge_Sort(a,0,n-1,tmp);//对数组进行排序
    for(int i=0;i 
 

大家看注释行事,注释基本在关键点都注明了,希望对大家有帮助 

总结

到此这篇关于C++归并排序算法详解的文章就介绍到这了,更多相关C++归并排序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的:(C++归并排序算法详解)