题解 | #合并两个排序的链表#

合并两个排序的链表

https://www.nowcoder.com/practice/d8b6b4358f774294a89de2a6ac4d9337

C语言思路:

第一步,首先看两个表其中是否有一个表是空表,是则返回另一个链表(不需要合并操作);

第二步,若都不为空,就初始化一个头结点作为合并后的表头结点,然后依次比较两个链表中的结点值,值小的就插入新表中,然后指针后移继续比较,重复此操作直至其中一个表为空或者都为空;

第三步,当两个表表长不一致时,即其中一个表的元素已经全部被插入到新表中了,由于两个表都是有序表,那么另外一个表中剩下的节点元素值自然都比已经新表中的节点元素值大,于是就直接把剩下的节点直接拼接到合并的新表后面即可。

运行时间:4ms 占用内存:512KB

代码(C)实现如下:

struct ListNode* Merge(struct ListNode* pHead1struct ListNode* pHead2 ) {

    // write code here

    if(pHead1==NULL){

        return pHead2;

    }

    if(pHead2==NULL){

        return pHead1;

    }

    struct ListNode* Head;

    Head = (struct ListNode *)malloc(sizeof(struct ListNode));

    struct ListNode* p = Head;

    while(pHead1!=NULL&&pHead2!=NULL)

    {

        if(pHead1->val > pHead2->val)

        {

            p->next = pHead2;

            pHead2 = pHead2->next;

            p = p->next;

        }else{

            p->next = pHead1;

            pHead1 = pHead1->next;

            p = p->next;

        }

    }

    if(pHead1==NULL){

        p->next = pHead2;

    }

    if(pHead2==NULL){

        p->next = pHead1;

    }

    return Head->next;

}

全部评论
以上只是个人理解(适合初学者理解),如有更好的思路欢迎各位大佬分享!
1
送花
回复
分享
发布于 2022-11-22 13:29 湖南

相关推荐

1 收藏 评论
分享
牛客网
牛客企业服务