C - 合并两个字符串列表

raf*_*ame 0 c list

我目前有这个算法:

char** mergeLists(char **a, char **b, int sizeA, int sizeB, int *lSize)
{
    char **list = malloc( sizeof(char *) );
    int pA = 0, pB = 0, listSize = 0;

    while (pA != sizeA && pB != sizeB)
    {
        list = realloc(list, sizeof(char *) * (++listSize) );

        if (strcmp(a[pA], b[pB]) < 0)
        {
            list[listSize-1] = a[pA];
            pA++;                
        }
        else
        {   
            list[listSize-1] = b[pB];
            pB++;   
        }    
    }

    *lSize = listSize;

    return list;
}
Run Code Online (Sandbox Code Playgroud)

但它似乎有一些错误.我目前正在运行此测试:

char *l1[6];
l1[0] = "a";
l1[1] = "b";
l1[2] = "c";
l1[3] = "d";
l1[4] = "e";
l1[5] = "f";

char *l2[6];
l2[0] = "aa";
l2[1] = "ba";
l2[2] = "ca";
l2[3] = "da";
l2[4] = "ea";
l2[5] = "fa";

int s;
char **l = mergeLists(l1, l2, 6, 6, &s);

int i = 0;
for(i = 0; i < s; i++)
    printf("%s\n", l[i]);
Run Code Online (Sandbox Code Playgroud)

它是印刷:

a
aa
b
ba
c
ca
d
da
e
ea
f
Run Code Online (Sandbox Code Playgroud)

缺少第二个列表的最后一项.我认为在while循环的条件下可能会出现一些错误.

我将不胜感激.谢谢.

Ign*_*ams 6

您的代码仅运行到任一列表的第一端.您需要在末尾添加两个循环以包括列表中尚未完全消耗的值.

  • 您必须补充循环内的条件以查找其中一个列表的耗尽. (2认同)