[c语言]将两个整形升序数组合并为一个升序数组
2014-07-10 16:42
309 查看
可能大多数人首先想到的是将两个数组合并,然后将合并后的数组排序输出。但是题目要求合并完即为一个升序数组,这样做不合题意。可以利用已知条件(两数组A、B均为升序),循环在每个数组中均选取一个元素来对比,较小的放到新数组C中。直到一个数组中的元素已全部放入C中,此时将另一个数组未放入的元素全放入到C中,代码如下。
//
// main.c
// c-last
//
// Created by 赵亚北 on 14-7-10.
// Copyright (c) 2014年 zyb. All rights reserved.
//
int main(int argc, const char * argv[])
{
int str1[5]={3,6,7,45,55};//两个升序数组
int str2[5]={8,10,11,22,25};
int out[10];//输出数组
int i=0,j=0,k=0;
while (i<5&&j<5){//循环将较小元素放入C
if (str1[i]<str2[j]) {
out[k]=str1[i];
i++;
k++;
}
else{
out[k]=str2[j];
j++;
k++;
}
}//while
if(i==5){//第1个数组元素已经全部放到C中,将第2个数组剩余元素全放到C中
while (j<5) {
out[k]=str2[j];
k++;
j++;
}
}
if(j==5){//第2个数组元素已经全部放到C中,将第1个数组剩余元素全放到C中
while (i<5) {
out[k]=str1[i];
k++;
i++;
}
}
for(int i=0;i<10;i++){
printf("%d ",out[i]);
}
}
运行结果为:
//
// main.c
// c-last
//
// Created by 赵亚北 on 14-7-10.
// Copyright (c) 2014年 zyb. All rights reserved.
//
int main(int argc, const char * argv[])
{
int str1[5]={3,6,7,45,55};//两个升序数组
int str2[5]={8,10,11,22,25};
int out[10];//输出数组
int i=0,j=0,k=0;
while (i<5&&j<5){//循环将较小元素放入C
if (str1[i]<str2[j]) {
out[k]=str1[i];
i++;
k++;
}
else{
out[k]=str2[j];
j++;
k++;
}
}//while
if(i==5){//第1个数组元素已经全部放到C中,将第2个数组剩余元素全放到C中
while (j<5) {
out[k]=str2[j];
k++;
j++;
}
}
if(j==5){//第2个数组元素已经全部放到C中,将第1个数组剩余元素全放到C中
while (i<5) {
out[k]=str1[i];
k++;
i++;
}
}
for(int i=0;i<10;i++){
printf("%d ",out[i]);
}
}
运行结果为:
相关文章推荐
- 编写一个程序,输入两个包含 5 个元素的数组,先将两个数组升序排序,然 后将这两个数组合并成一个升序数组(合并排序)。
- 将两个整形数组排序后合并成一个数组
- 已知m和n是已经排序好的数组,从小到大,现在要合并这两个数组内的数到一个数组,仍然要求是从小到大排序
- js 合并两个数组,去除重复项,只留一个
- 两个有序数组合并为一个有序数组
- Java中如何把两个数组合并为一个
- 输入一个升序数组和一个整数,在数组里面找两个数使它们相加的和为这个整数
- 两个有序数组合并为一个有序数组
- 24、合并两个无序数组,并把合并后的升序数组写入到a.txt中,降序数组写入到b.txt中。要求去掉重复元素
- 两个有序数组合并成一个有序数组
- 设有两个有序(升序)序列存储在同一数组中相邻的位置上,不妨设为A[l..m],A[m+1..h],将它们归并为一个有序数列,并存储在A[l..h]。
- 已知m和n是已经排序好的数组,从小到大,现在要合并这两个数组内的数到一个数组,仍然要求是从小到大排序
- 合并两个数组内容到一个新数组
- php使用array_combine合并两个数组为一个数组
- 两个升序链表,合并成一个升序链表
- 两个已经排好序的数组合并到一个数组中
- 线性表a、b为两个有序升序的线性表,编写一程序,使两个有序线性表合并成为一个有序升序线性表h
- 数据结构 - 有两个链表,第一个升序,第二个降序,合并为一个升序链表(C++)
- 两个链表一升一降,合并为一个升序链表。
- [C语言] 文件操作,合并两个二进制文件为单独一个二进制文件;