c語言之合併排序實現
#include <stdlib.h>
#include <string.h>
//將兩個有序序列合併為一個有序序列
void merge(int a[],int left_pos,int right_pos)
{
int temp[right_pos-left_pos+1];
int mid=(left_pos+right_pos)/2;
int left=left_pos,right=mid+1;
int count=0;
while(left<=mid&&right<=right_pos)
{
if(a[left]<=a[right])
{
temp[count++]=a[left++];
}
else
{
temp[count++]=a[right++];
}
}
while(left<=mid)
{
temp[count++]=a[left++];
}
while(right<=right_pos)
{
temp[count++]=a[right++];
}
memcpy(&a[left_pos],temp,sizeof(temp));
}
//合併排序
void merge_sort(int a[],int left_pos,int right_pos)
{
if(left_pos<right_pos)
{
//一分為二
int mid=(left_pos+right_pos)/2;
//左合併
merge_sort(a,left_pos,mid);
//右合併
merge_sort(a,mid+1,right_pos);
//合而為一
merge(a,left_pos,right_pos);
}
}
int main()
{
//測試用例
int a[]={331,34,43,64,75,43,7,4234,876,34};
//合併排序
merge_sort(a,0,9);
//列印結果
int i;
for(i=0;i<10;i++)
{
printf("%d ",a[i]);
}
printf("\n");
system("pause");
return 1;
}