栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

LeetCode 21. 合并两个有序链表

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

LeetCode 21. 合并两个有序链表

 这题单从思想上来说,和归并排序差不多,使用两个指针分别指向两个链表的开头,比较大小,将较小的插入到新的链表中。在其中一个链表循环完成后,将另一个链表的剩余部分接上即可。AC代码如下:

class Solution {
public:
    ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) {
        ListNode* left = list1;
        ListNode* right = list2;
        ListNode* ans = new ListNode;
        ListNode* tail = ans; 
        for(;left!=nullptr&&right!=nullptr;) {
            if((left->val) <= (right->val)) {
                tail->next = left;
                left = left->next;
            }else {
                tail->next = right;
                right = right->next;
            }
            tail = tail->next;
        }
        for(;left!=nullptr;left=left->next) {
            tail->next = left;
            tail = tail->next;
        }
        for(;right!=nullptr;right=right->next) {
            tail->next = right;
            tail = tail->next;
        }
        return ans->next;
    }
};

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/717561.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号