题目描述
输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。
示例
输入:{1,3,5},{2,4,6}
输出:{1,2,3,4,5,6}
算法思路
采用归并排序的思想:
- 定义新的头结点,和两个指针分别指向链表1和链表2
- 比较链表1和链表2的值,比较小的值插入到新的链表头后面,然后移动指针,另一个指针不动。循环往复,直到某个链表的指针指到空结点
- 最后把非空链表拼接到新链表后面
代码实现
/*
public class ListNode {
int val;
ListNode next = null;
ListNode(int val) {
this.val = val;
}
}*/
public class Solution {
public ListNode Merge(ListNode list1,ListNode list2) {
//定义一个新的头节点
ListNode head = new ListNode(0);
//新的链表头的移动指针
ListNode cur = head;
while(list1 != null && list2!=null){
if(list1.val<=list2.val){
cur.next = list1;
list1 = list1.next;
}else{
cur.next = list2;
list2 = list2.next;
}
cur = cur.next;
}
//把非空链表插入到后面
cur.next = (list1==null) ? list2 : list1;
return head.next;
}
}