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

合并两个排序的链表

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&&pHead2==nullptr){
			return nullptr;
		}
		if(pHead1==nullptr&&pHead2!=nullptr){
			return pHead2;
		}
		if(pHead1!=nullptr&&pHead2==nullptr){
			return pHead1;
		}
		ListNode *p1=pHead1->next;
        ListNode *p2=pHead2->next;
		ListNode *ans;
		if(pHead1->val>pHead2->val){
			ans=pHead2;
			while(pHead1->val>p2->val){
				pHead2=pHead2->next;
				p2=pHead2->next;
				if(p2==nullptr){
					pHead2->next=pHead1;
					return ans;
				}
			}
			pHead2->next=pHead1;
			pHead2=p2;
			p2=p2->next;
		}
		else{
			ans=pHead1;
		}
		while(pHead1!=nullptr&&pHead2!=nullptr){
			if(p1==nullptr){
				break;
			}
			if(p1->val>pHead2->val){
				pHead1->next=pHead2;
				pHead2->next=p1;
				pHead1=pHead2;
				pHead2=p2;
				if(p2!=nullptr){
					
					p2=p2->next;
				}		
			}
			else{
				if(p1!=nullptr){
					p1=p1->next;
				}
				else{
					p1=pHead1;
				}
				pHead1=pHead1->next;
			}
		}
		if(p1==nullptr){
			pHead1->next=pHead2;
		}
		return ans;
    }
};

全部评论

相关推荐

今天 12:43
已编辑
门头沟学院 C++
点赞 评论 收藏
分享
牛客771574427号:恭喜你,华杰
点赞 评论 收藏
分享
拒绝无效加班的小师弟很中意你:求职意向没有,年龄、课程冗余信息可以删掉,需要提升项目经历。排版需要修改。
点赞 评论 收藏
分享
Pandaileee:校友加油我现在也只有一个保底太难了
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务