参考自:《剑指Offer——名企面试官精讲典型编程题》
题目:合并两个排序的链表
输入两个递增排序的链表,合并这两个链表并使新链表中的结点仍然是按照递增排序的。
主要思路:比较两个链表的当前结点,找出值较小的结点,将该结点添加到新链表的尾部。该过程可通过递归实现,其中要注意链表为空的情况。
关键点:递归
时间复杂度:O(n),n为两个链表的长度之和
public class MergeLinkedList
{
public static void main(String[] args)
{
int[] data1 = {2, 4, 6};
int[] data2 = {1, 3, 5};
ListNode pHead1 = LinkedListData.GenerateDataByArray(data1);
ListNode pHead2 = LinkedListData.GenerateDataByArray(data2);
ListNode result = merge(pHead1, pHead2);
LinkedListData.WriteData(result);
}
private static ListNode merge(ListNode list1, ListNode list2)
{
if (list1 == null)
{
return list2;
}
if (list2 == null)
{
return list1;
}
ListNode newNode = null;
if (list1.val <= list2.val)
{
newNode = list1;
newNode.next = merge(list1.next, list2);
} else
{
newNode = list2;
newNode.next = merge(list1, list2.next);
}
return newNode;
}
}
class ListNode
{
int val;
ListNode next = null;
ListNode(int val)
{
this.val = val;
}
}