两数组合并后排序实现函数:
void mergelist(int *a,int len_a,int *b,int len_b,int*c)
{
int i=0;//用来判断数组a
int j=0;//用来判断数组b
int k=0;//用来标识数组c
while(i<len_a&&j<len_b)//两个数组都为非空时
{
if(a[i]<b[j])
{
c[k]=a[i];
i++;
k++;
}else{
c[k]=b[j];
j++;
k++;
}
}
while(i<len_a)//数组b的值已经被移到c中,数组a的值还没有完全被移到c中
{
c[k]=a[i];
i++;
k++;
}
while(j<len_b)//数组a的值已经完全被移到c中,数组b的值还没有完全被移到c中
{
c[k]=b[j];
j++;
k++;
}
}
两数组合并后不排序实现函数:
void mergelist(int *a,int len_a,int *b,int len_b,int*c)
{
int i=0;//用来判断数组a
int j=0;//用来判断数组b
int k=0;//用来标识数组c
while(i<len_a&&j<len_b)//两个数组都为非空时
{
while(i<len_a)
{
c[k]=a[i];
i++;
k++;
}
while(j<len_b)
{
c[k]=b[j];
j++;
k++;
}
}
}