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

合并两个排序的链表

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

/*
struct ListNode {
    int val;
    struct ListNode *next;
    ListNode(int x) :
            val(x), next(NULL) {
    }
};*/
class Solution {
  public:
    ListNode* Merge(ListNode* pHead1, ListNode* pHead2) {
	  //任意一个链表为空就返回另一个链表
		if(pHead1==nullptr) return pHead2;
		if(pHead2==nullptr) return pHead1;
	  
        ListNode* head, *p, *q, *r;
	  //选择pHead1,pHead2中头结点val较小的作为新链表的头结点,遍历另一个链表往里插数据
        if (pHead2->val > pHead1->val) {
            head = pHead1;
            p = pHead2;
        } else {
            head = pHead2;
            p = pHead1;
        }
        r = head;
        while (p != nullptr && r->next!=nullptr) {
            if (p->val >= r->val && p->val <= r->next->val) {//比r小比r->next大就插进去
                q = p->next;
                p->next = r->next;
                r->next = p;
                r = p;
                p = q;
            } else {
                r = r->next;
            }
        }
	  //若r遍历完了p还没遍历完,则说明剩下的p都比r大
		if(p!=nullptr) r->next = p;
        return head;
    }
};

全部评论

相关推荐

不愿透露姓名的神秘牛友
今天 14:00
点赞 评论 收藏
分享
nus2201602...:兄弟,你这个简历撕了丢了吧,就是一坨,去找几个项目,理解项目流程,看几遍就是你的了,看看八股就去干了,多看看牛客里别人发出来的简历,对着写,你这写的啥啊,纯一坨
点赞 评论 收藏
分享
屌丝逆袭咸鱼计划:心态摆好,man,晚点找早点找到最后都是为了提升自己好进正职,努力提升自己才是最关键的😤难道说现在找不到找的太晚了就炸了可以鸡鸡了吗😤早实习晚实习不都是为了以后多积累,大四学长有的秋招进的也不妨碍有的春招进,人生就这样
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务