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

合并两个排序的链表

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

/**
     * so easy
     * @param list1
     * @param list2
     * @return
     */
    public ListNode Merge(ListNode list1, ListNode list2) {
        ListNode cur1 = list1;
        ListNode cur2 = list2;
        ListNode node = new ListNode(0);
        ListNode cur = node;
        while (cur1 != null && cur2 != null) {
            if (cur1.val < cur2.val) {
                cur.next = cur1;
                cur1 = cur1.next;
            } else {
                cur.next = cur2;
                cur2 = cur2.next;
            }
            cur = cur.next;
        }
        while (cur1 != null) {
            cur.next = cur1;
            cur = cur.next;
            cur1 = cur1.next;
        }
        while (cur2 != null) {
            cur.next = cur2;
            cur = cur.next;
            cur2 = cur2.next;
        }
        return node.next;
    }
算法 文章被收录于专栏

数据结构和算法

全部评论
while (cur1 != null) while (cur2 != null) 其实可以用if代替,cur直接把不是null的串起来就可以了,不需要再每次去往后做next了
点赞 回复 分享
发布于 2022-01-20 20:25
请问解法1和解法2的空间复杂度是不是是O(N)呀?
点赞 回复 分享
发布于 2022-01-13 18:34

相关推荐

有了offer来还愿:学校不行,专业不行,学历不行,怎么找?
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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