思路:
用一个虚拟头节点 接住结果,然后像拉链一样,谁小就先拿谁。
建一个虚拟头 dummy,用 cur 往后拼接
-
同时遍历 list1、list2
-
谁小就把谁接到 cur 后面,然后那条链表指针后移
-
最后把剩下不为空的整条直接接上
-
返回 dummy.next
合并链表的 "神器":虚拟头节点 后面跟一个移动指针 专门用来往后拼接新节点
完整代码实现:
java
class Solution {
public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
// 分别遍历两条链表 每次取较小的值加入新链表中 返回新链表
//定义一个结果链表的头节点
ListNode dummy = new ListNode(-1);
ListNode curr = dummy; //移动指针用来拼后面结点的
while(list1 != null && list2 != null){
if(list1.val<=list2.val){
curr.next = list1;
list1 = list1.next;
}else{
curr.next = list2;
list2 = list2.next;
}
curr = curr.next;
}
// 剩下的直接拼上去
if (list1 != null) {
curr.next = list1;
}
if (list2 != null) {
curr.next = list2;
}
return dummy.next;
}
}