标题:
C语言分治排序算法
[打印本页]
作者:
rocfly
时间:
2018-1-27 11:58
标题:
C语言分治排序算法
分治排序算法
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
/*将A数组中p到r元素进行分治排序*/
MERGE(int *A, int p, int q, int r)
{
int n1 = q - p + 1;//数组L中元素个数
int n2 = r - q;//数组R中元素个数
int *L, *R;
int i;
int j;
int k;
L = malloc( ( n1 + 1 ) * sizeof( int ) );
R = malloc( ( n2 + 1 ) * sizeof( int ) );
for( i = 0; i < n1; i++ )
{
*( L + i ) = *( A + p + i );//A[p]到A[q]
}
for( i = 0; i < n2; i++ )
{
*( R + i ) = *( A + q + i + 1 );//A[q+1]到A[r]
}
L[n1] = 2147483647;//2^31-1
R[n2] = 2147483647;//2^31-1
i=0;
j=0;
for( k = p; k <= r; k++ )
{
if( L[i] <= R[j] )
{
A[k] = L[i];
i = i + 1;
}
else
{
A[k] = R[j];
j = j + 1;
}
}
free( L );
free( R );
}
MERGE_SORT( int *A, int p, int r )
{
int q;
if( p < r )
{
q = ( int )floor( ( p + r ) / 2 );
MERGE_SORT( A , p , q );
MERGE_SORT( A , q+1 , r );
MERGE( A , p , q , r );
}
}
main()
{
int i;
int x[100];
for( i = 0; i < 10; i++ )
{
x[i] = rand() % 100;
printf("x[%d] = %d\n", i, x[i] );
}
MERGE_SORT( x , 0 , 9 );
for( i = 0; i < 10; i++ )
{
printf("x[%d] = %d\n", i, x[i] );
}
getch();
}
复制代码
分治排序.rar
2018-1-27 11:58 上传
点击文件名下载附件
下载积分: 黑币 -5
656 Bytes, 下载次数: 4, 下载积分: 黑币 -5
欢迎光临 (http://www.51hei.com/bbs/)
Powered by Discuz! X3.1