免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1597 | 回复: 0
打印 上一主题 下一主题

C语言归并排序 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-10-24 20:49 |只看该作者 |倒序浏览
#include <tchar.h>
#include <iostream>
#include <algorithm>
#include <iterator>
//复制函数

//此教程来源于ChinaUnix論壇(http://bbs.chinaunix.net/)查看完整的教程请点:http://bbs.chinaunix.net/thread-1296106-1-1.html

template <typename T>
void copy(T* begin, T* end, T* out)
{
while ( begin!=end )
{
&nbsp;&nbsp;*out=*begin;
&nbsp;&nbsp;++out;
&nbsp;&nbsp;++begin;
}
}
//将两个有序数组合并到一个数组中

template <typename T>
void merge(T* begin1, T* end1, T* begin2, T* end2, T* out)
{
for ( ;; )
{
&nbsp;&nbsp;if ( begin1!=end1 && begin2!=end2 )
&nbsp;&nbsp;{
&nbsp;&nbsp;&nbsp;if ( *begin1<*begin2 )
&nbsp;&nbsp;&nbsp;{
&nbsp;&nbsp;&nbsp;&nbsp;*out=*begin1;
&nbsp;&nbsp;&nbsp;&nbsp;++begin1;
&nbsp;&nbsp;&nbsp;}
&nbsp;&nbsp;&nbsp;else
&nbsp;&nbsp;&nbsp;{
&nbsp;&nbsp;&nbsp;&nbsp;*out=*begin2;
&nbsp;&nbsp;&nbsp;&nbsp;++begin2;
&nbsp;&nbsp;&nbsp;}
&nbsp;&nbsp;}
&nbsp;&nbsp;else if ( begin1!=end1 )
&nbsp;&nbsp;{
&nbsp;&nbsp;&nbsp;*out=*begin1;
&nbsp;&nbsp;&nbsp;++begin1;
&nbsp;&nbsp;}
&nbsp;&nbsp;else if ( begin2!=end2 )
&nbsp;&nbsp;{
&nbsp;&nbsp;&nbsp;*out=*begin2;
&nbsp;&nbsp;&nbsp;++begin2;
&nbsp;&nbsp;}
&nbsp;&nbsp;else
&nbsp;&nbsp;{
&nbsp;&nbsp;&nbsp;break;
&nbsp;&nbsp;}
&nbsp;&nbsp;++out;
}
}
//归并排序

template <typename T>
void MergeSort(T data[], int size)
{
if ( size>1 ) //数组元素要大于两个才有排序的必要

{
&nbsp;&nbsp;//将数组二分

&nbsp;&nbsp;int lsize=size/2;
&nbsp;&nbsp;int rsize=size-lsize;
&nbsp;&nbsp;T* left=new T[lsize];
&nbsp;&nbsp;T* right=new T[rsize];
&nbsp;&nbsp;::copy(data, data+lsize, left);
&nbsp;&nbsp;::copy(data+lsize, data+size, right);
&nbsp;&nbsp;//递归

&nbsp;&nbsp;MergeSort(left, lsize);
&nbsp;&nbsp;MergeSort(right, rsize);
&nbsp;&nbsp;//合并

&nbsp;&nbsp;::merge(left, left+lsize, right, right+rsize, data);
&nbsp;&nbsp;//删除辅助空间

&nbsp;&nbsp;delete[] left;
&nbsp;&nbsp;delete[] right;
}
}
//测试例程

int _tmain(int argc, _TCHAR* argv[])
{
int data[10000];
for ( int i=0; i<10000; ++i )
{
&nbsp;&nbsp;data[i]=rand()%1000;
}
MergeSort(data, 10000);
std::copy(data, data+10000, std::ostream_iterator<int>(std::cout, " "));
return 0;
}


[ 本帖最后由 langue 于 2008-10-25 08:00 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP