归并排序

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

template <class T>
void
merge(T* array, int left, int mid, int right, T* temp)
{
  int i =left;
  int j =mid+1;
  int p=0;
  while(i<=mid && j <=right){
    if(array[i]>array[j]){
      temp[p++]=array[j++];
    }else{
      temp[p++]=array[i++];
    }
  }
  if(j<=right){
    memcpy(temp+p, array+j, sizeof(T)*(right-j+1));
  }else if(i<=mid){
    memcpy(temp+p, array+i, sizeof(T)*(mid-i+1));
  }
  memcpy(array+left, temp, sizeof(T)*(right-left+1));
}

template <class T>
void
mergesort(T* array, int left, int right, T* temp)
{
  if(left >= right)
    return;
  int mid = (left+right)/2;
  mergesort(array, left, mid, temp);
  mergesort(array, mid+1, right, temp);
  merge(array, left, mid, right, temp);
}

int
main()
{
  int array[10]={9,8,7,6,5,40,3,2,1,0};
  int temp[10];
  int len = sizeof(array)/sizeof(int);
  mergesort(array, 0, len, temp);
  for(int i=0; i<len; ++i){
    printf("%d ", array[i]);
  }
  printf("\n");
}

转载于:https://www.cnblogs.com/zjfdlut/archive/2011/04/30/2033450.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值