sorting - merge sort

#include "stdio.h"
#include "string.h"

#define MAX_LIST 50


typedef struct _SqList {
    int data[MAX_LIST];
    int length;
}SqList;

enum MERGE_SORT_METHOD { RECURSE, ITERATE };

void Merge( int src[], int dst[], int start, int middle, int end)
{
    int j, k;
    for( k = start, j = middle + 1; start <= middle && j <= end; k++   )
    {
        if( src[start] < src[j] )
            dst[k] = src[start++];
        else
            dst[k] = src[j++];      
    }

    while( start <= middle ) dst[k++] = src[start++];
    while( j <= end ) dst[k++] = src[j++];      
}

void MSort( int src[], int dst[], int start, int end )
{
    if( start == end )
        dst[start] = src[start];
    else{
        int middle = (start + end)/2;
        int buf[MAX_LIST];
        MSort(src, buf, start, middle);
        MSort(src, buf, middle+1, end);
        Merge(buf, dst, start, middle, end );
    }
}
void MergeSortRecursive( SqList* L )
{
     MSort( L->data, L->data, 0, L->length-1 );
}

void MergePiecewise( int src[], int dst[], int piece, int count )
{
    int i = 0;
    while( i < count - 2*piece + 1)
    {
        Merge( src, dst, i, i+piece-1, i+2*piece-1);
        i += 2*piece;
    }   
    if( i < count -  piece + 1 )
        Merge( src, dst, i, i + piece - 1, count-1);
    else
        while( i < count )
            dst[i] = src[i++];
}
void MergeSortIterative( SqList* L )
{
    int buf[MAX_LIST];

    int block = 1;
    while( block < L->length )
    {
        MergePiecewise( L->data, buf, block, L->length  );
        block *= 2;
        MergePiecewise( buf, L->data, block, L->length );
        block *= 2;
    }
}

void MergeSort( SqList* L, MERGE_SORT_METHOD ms )
{
    if( ms == RECURSE )
        MergeSortRecursive( L );
    else
        MergeSortIterative( L );
}

int main()
{
    SqList d;
    int intarr[] = {1,10,23,48,65,31,-21,9,88,100};
    printf("array length is %d\n", sizeof(intarr));
    memcpy( d.data, intarr, sizeof(intarr));
    d.length = sizeof(intarr)/sizeof(int);  
    int index = 0;
    for( ; index < d.length; index++ )
        printf(" %d", d.data[index] );
    printf("\nMerge sort...\n");
    MergeSort( &d, RECURSE );
    for( index = 0; index < d.length; index++ )
        printf(" %d", d.data[index] );
    printf("\n");
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值