C语言合并排序

C语言合并排序合并排序C语言实现#include#defineLENA10#defineLENB5voidMergeSort(int*array1,intlen1,int*array2,intlen2){ inti=0,j=0,k=0; intdata[LENA+LENB]={0}; while(kLENA

大家好,欢迎来到IT知识分享网。C语言合并排序"

合并排序C语言实现

#include <stdio.h>

#define LENA 10
#define LENB 5

void MergeSort( int * array1 , int len1 , int * array2 , int len2 )
{
	int i = 0 , j = 0 , k = 0;
	int data[LENA+LENB] = { 0 };

	while ( k < LENA+LENB )
	{
		if ( array1[i] < array2[j] )
		{
			if ( i < len1 )
			{
				data[k] = array1[i];
				i++;
			}
			else
			{
				data[k] = array2[j];
				j++;
			}
		}
		else
		{
			if ( j < len2 )
			{
				data[k] = array2[j];
				j++;
			}
			else
			{
				data[k] = array1[i];
				i++;
			}
		}
		k++;
	}

	for ( int a = 0 ; a < k ; a++ )
	{
		printf( "%d " , data[a] );
	}
	printf( "\n" );
}

void main()
{
	int a[] = { 0 , 1 , 2 , 3 , 5 , 9 , 11 , 100 , 1000 , 9999 };
	int b[] = { 9 , 11 , 100 , 300 , 1000 };
	MergeSort( a , LENA , b , LENB );
}

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/14386.html

(0)
上一篇 2024-02-29 15:15
下一篇 2024-03-01 18:00

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信