码迷,mamicode.com
首页 > 其他好文 > 详细

每天AC系列(七):合并两个有序链表

时间:2020-01-30 00:04:22      阅读:92      评论:0      收藏:0      [点我收藏+]

标签:不难   返回值   描述   ever   lse   tps   归并   技术   href   

1 题目

LeetCode第21题,合并两个有序链表.
技术图片

2 直接合并

因为已经有序了,类似归并排序中的合并一样,操作不难,直接上代码了.

ListNode t = new ListNode(0);
ListNode head = t;
while(l1 != null && l2 != null)    
{
    if(l1.val < l2.val)
    {
        t.next = l1;
        l1 = l1.next;
    }
    else
    {
        t.next = l2;
        l2 = l2.next;
    }
    t = t.next;
}
while(l1 != null)
{
    t.next = l1;
    l1 = l1.next;
    t = t.next;
}
while(l2 != null)
{
    t.next = l2;
    l2 = l2.next;
    t = t.next;
}
return head.next;

技术图片

3 递归合并

这个可以采用递归优化,而且不用额外设置一个移动的临时结点t.首先对两个指针进行判空操作,其中一个为空的话返回另一个,然后进行递归合并,首先创建一个head结点,进行赋值后递归合并next结点,将返回值赋给head.next,最后返回head.

if(l1 == null) return l2;
if(l2 == null) return l1;

ListNode head = null;
if(l1.val < l2.val)
{
    head = l1;
    head.next = mergeTwoLists(l1.next, l2);
}
else
{
    head = l2;
    head.next = mergeTwoLists(l1, l2.next);
}
return head;

4 源码

github

码云

每天AC系列(七):合并两个有序链表

标签:不难   返回值   描述   ever   lse   tps   归并   技术   href   

原文地址:https://www.cnblogs.com/Blueeeeeeee/p/12241772.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!