merge sort

归并排序:归并排序(英语:Merge sort,或mergesort),是创建在归并操作上的一种有效的排序算法,效率为O(n log n)。1945年由约翰·冯·诺伊曼首次提出。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用,且各层分治递归可以同时进行。

该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。

归并排序是稳定排序,它也是一种十分高效的排序

 

 

 

void mergeSort ( int array[], int min, int max)
{
    // prerequisite
    if (min < max)
    {
        // get the middle point
        int mid = ( int )floor((max + min) / 2) ;
        // apply merge sort to both parts of this
        mergeSort(array, min, mid) ;
        mergeSort(array, mid + 1, max) ;
        // and finally merge all that sorted stuff
        merge(array, min, max, mid) ;
    }
}
void merge ( int array[], int min, int max, int mid)
{
    int firstIndex = min ;
    int secondIndex = mid + 1 ;
    int index = min ;
    int tempArray[max] ;
    // if there are still objects in both arrays
    while ((firstIndex <= mid) && (secondIndex <= max))
    {
        if (array[firstIndex] < array[secondIndex])
        {
            tempArray[index] = array[firstIndex] ;
            index ++ ;
            firstIndex ++ ;
        }
        else
        {
            tempArray[index] = array[secondIndex] ;
            index ++ ;
            secondIndex ++ ;
        }
    }
    // terminates the object of the lower array
    while (firstIndex <= mid)
    {
        tempArray[index] = array[firstIndex] ;
        index ++ ;
        firstIndex ++ ;
    }
    // terminates the object of the upper array
    while (secondIndex <= max)
    {
        tempArray[index] = array[secondIndex] ;
        index ++ ;
        secondIndex ++ ;
    }
    // transfer to the initial array
    for ( int i = min ; i < index ; i ++ )
        array[i] = tempArray[i] ;
}

 

总的平均时间复杂度为O(nlogn)。而且,归并排序的最好,最坏,平均时间复杂度均为O(nlogn)。

posted @ 2018-07-22 21:22  PKICA  阅读(190)  评论(0编辑  收藏  举报