LeetCode Algorithm 21. 合并两个有序链表

Posted Alex_996

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode Algorithm 21. 合并两个有序链表相关的知识,希望对你有一定的参考价值。

题目链接:21. 合并两个有序链表

Ideas

算法:归并排序最后Merge
数据结构:链表
思路:这道题考察的就是归并排序最后两个有序链表合并的阶段。首先还是要创建一个空链表res用来表示最终的返回结果。然后对于两个链表的指针,开始分别指向两个链表的第一个元素,然后两个指针往前走,并比较相应位置上元素的大小,取大的那个元素拿到res,以此类推最终直到有一个指针走到相应链表的末尾。最后有可能其中一个指针没有走到链表末尾,那么直接将res的下一个元素指向该指针对应的链表即可。
补充:关于归并排序的具体实现和动画演示可以参考博客:教小学妹学算法:十大经典排序算法深度解析

Code

C++

class Solution 
public:
    ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) 
        ListNode* res = new ListNode(-1);
		ListNode* prev = res;
		
		while (list1 != nullptr && list2 != nullptr) 
			if (list1->val < list2->val) 
				prev->next = list1;
				list1 = list1->next;
			 else 
				prev->next = list2;
				list2 = list2->next;
			
			prev = prev->next;
		
		
		prev->next = list1 == nullptr ? list2 : list1;
		return res->next;
    
;

以上是关于LeetCode Algorithm 21. 合并两个有序链表的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode Algorithm 1669. 合并两个链表

LeetCode Algorithm 2181. 合并零之间的节点

LeetCode Algorithm 1669. 合并两个链表

LeetCode Algorithm 2181. 合并零之间的节点

LeetCode Algorithm 1669. 合并两个链表

LeetCode Algorithm 2181. 合并零之间的节点