| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 266 人关注过本帖
标题:想问下动态数组的问题,要两个有序的数组合成一个,一次性完成。
只看楼主 加入收藏
NeQhk
Rank: 2
等 级:论坛游民
威 望:1
帖 子:164
专家分:85
注 册:2014-7-19
结帖率:69.23%
收藏
 问题点数:0 回复次数:0 
想问下动态数组的问题,要两个有序的数组合成一个,一次性完成。
#include <stdio.h>
int main()
{
    int *a;//是不是这里用指针,等下就可以用realloc了。
    int *b;
    int i=0,j=0,k;
    printf ("请输入第一个数组:\n");
   
     while (  scanf("%d",&a[i])==1&&a[i]!='\n')
     {
         i++;
     }
     a[i]='\0';
     printf ("输入第二个数组:\n");
     while (scanf("%d",&b[j])==1&&b[i]!='\n')
     {
         j++;
     }
     b[i]='\0';
     j--;
     k=i+j;
     a=(int *)realloc(a,k*sizeof(int));//用realloc 怎么扩充之前的数组同时又
     i=0;不覆盖之前的数组?
     j=0;
     while (i<k)
     {
         while (a[i]!='\0'&&b[j]!='\0')
         {
             if(a[i]<b[j])
             {
                 i++;
             }
             else if(a[i]>b[j])
             {
                 a[i++]=b[j++];
             }
             else
             {
                 i++;
                 j++;
             }
         }
         while (a[i]!='\0')
         {
             i++;
         }
         while(b[j]!='\0')
         {
             a[i++]=b[j++];
         }
     }
         i=0;
         while (a[i]!='\0')
         printf ("%d",a[i]);
         return 0;
}
搜索更多相关主题的帖子: include 动态 
2015-04-10 00:17
快速回复:想问下动态数组的问题,要两个有序的数组合成一个,一次性完成。
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.014358 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved