题解 | #合并两个排序的链表#

合并两个排序的链表

http://www.nowcoder.com/practice/d8b6b4358f774294a89de2a6ac4d9337

链表结构:

/*
public class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}*/

解法一、常规思路

public class Solution {
    public ListNode Merge(ListNode l1, ListNode l2) {
        ListNode head = new ListNode(0), p = head; // head头结点,避免找不到链表头
        while (l1 != null && l2 != null) {
            if (l1.val <= l2.val) {
                p.next = l1;
                l1 = l1.next;
            } else {
                p.next = l2;
                l2 = l2.next;
            }
            p = p.next;
        }
        p.next = l1 != null ? l1: l2;
        return head.next;
    }
}

解法二、递归解法

public class Solution {
    public ListNode Merge(ListNode l1, ListNode l2) { 
        ListNode head = new ListNode(-1); // head头结点,防止找不到头
        doMerge(head, l1, l2);
        return head.next;
    }

    // 递归辅助函数
    private void doMerge(ListNode head, ListNode l1, ListNode l2) {
        if (l1 == null || l2 == null) {
            head.next = l1 == null ? l2 : l1; // 三元运算写起来简单但是性能很差
            return ; // 递归终止条件
        }
        if (l1.val <= l2.val) {
            head.next = l1;
            doMerge(head.next, l1.next, l2);
        } else {
            head.next = l2;
            doMerge(head.next, l1, l2.next);
        }
    }
}
全部评论

相关推荐

找个工作&nbsp;学历是要卡的&nbsp;要求是高的&nbsp;技能不足是真的&nbsp;实习经验是0的&nbsp;简历无处可写是事实的&nbsp;钱不好赚是真的&nbsp;想躺平又不敢躺&nbsp;也不甘心躺&nbsp;怕自己的灵感和才华被掩埋甚至从未被自己发现&nbsp;又质疑自己是否真正有才华
码农索隆:你现在啊,你心里都明白咋回事,但是你没办法改变现状,一想到未来,你又没有信心狠下心来在当下努力。 得走出这种状态,不能一直困在那里面,哪不行就去提升哪,你一动不动那指定改变不了未来,动起来,积少成多才能越来越好
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
06-04 15:20
牛客61197583...:看到室友一个个没怎么学通过关系直接入职或者接到面试,真的很难受。八股不知道背了多少遍,hot100也刷了1.5遍了,但就是没有面试的机会,唉
点赞 评论 收藏
分享
买蜜雪也用卷:我觉得应该没有哪个人敢说自己熟练使用git,代码分支一复杂还是得慢慢寻思一下的,不过基本的拉代码提交代码还有分支什么的是应该会
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务