合併排序法

 

合併排序法

{         持續將一堆沒有順序的資料分割成兩半,直到每一份都只有一筆資料

{         將分割完畢的資料兩兩合併

 


 

e.g.

12    5     9     15     7

                 

                 12    5    9                15      7

 

               12    5         9            15         7

 

              12      5

 

 

 

#include<stdio.h>

int a[]={12,5,9,15,7};

int b[5];

void merge(int lo, int m,int hi)

{

     int i, j, k;

    // copy both halves of a to auxiliary array b

    for (i=lo; i<=hi; i++)

        b[i]=a[i];

     

    i=lo; j=m+1; k=lo;

    // copy back next-greatest element at each time

    while (i<=m && j<=hi)

        if (b[i]<=b[j])

            a[k++]=b[i++];

        else

            a[k++]=b[j++];

 

    // copy back remaining elements of first half (if any)

    while (i<=m)

        a[k++]=b[i++];

}

 

void mergesort(int lo, int hi)

{

    if (lo<hi)

    {

        int mid=(lo+hi)/2;

        mergesort(lo, mid);

        mergesort(mid+1, hi);

        merge(lo, mid, hi);

    }

}

 

int main()

{

     int lo,hi,i;

     lo=0;

     hi=4;

     mergesort(lo,hi);   

     for(i=0;i<5;i++)

        printf("%d ",a[i]);

     printf("\n");

     getche();

     return 1;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值