题目:
输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。
输入:{1,3,5},{2,4,6}
返回值:{1,2,3,4,5,6}
思路:
- 由于两个链表都是递增的,所以我们可以在遍历的同时,判断每个链表当前各自值的大小,取出较小的那个,作为新链表的结点,否则取另一个,直到一个链表为空,将剩下一个链表拼接至新链表尾端
- 注意:创建链表使用虚拟头结点
代码:
/*
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 result = new ListNode(-1);
ListNode cur = result;
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 result.next;
}
}