题目
将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
思路
可以用递归来解决,要合并两个有序链表,即每次从两个链表的头结点中选择较小的加入到新链表,并对剩下的链表再次进行同样的操作。
若其中一个链表(list1)为空,则直接返回另一个链表(list2)的首地址list2即可。否则比较两个链表第一个节点的大小,若list1的节点数值较小,则返回的值应当是list1的首地址,list1的next应该指向排序后的剩下的结点,即对除list1外的所有结点进行递归操作。
代码
ListNode mergeTwoLists(ListNode list1, ListNode list2) {
if(list1==null)
return list2;
if(list2==null)
return list1;
if(list1.val<list2.val){
list1.next=mergeTwoLists(list1.next,list2);
return list1;
}else{
list2.next=mergeTwoLists(list1,list2.next);
return list2;
}
}
博客围绕将两个升序链表合并为一个新升序链表的问题展开。介绍了使用递归的思路,即每次从两个链表头结点选较小的加入新链表,对剩余链表重复操作。若一个链表为空则返回另一个链表首地址,还给出了相应代码。
195

被折叠的 条评论
为什么被折叠?



