力扣题目学习笔记(OC + Swift)21. 合并两个有序链表

21. 合并两个有序链表

将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。

链表解题经典三把斧:

  • 哑巴节点
  • 快慢指针

此题比较容易想到的解法是迭代法,生成哑巴节点,然后迭代生成后续节点。

方法一、迭代法

Swift

swift 复制代码
func mergeTwoLists(_ list1: ListNode?, _ list2: ListNode?) -> ListNode? {
        guard list1 != nil else {
            return list2
        }

        guard list2 != nil else {
            return list1
        }

        var list1 = list1
        var list2 = list2

        let dummyNode = ListNode(-1);
        var prev:ListNode? = dummyNode

        while list1 != nil && list2 != nil {
            if list1!.val < list2!.val {
                prev?.next = list1
                list1 = list1!.next
            }else {
                prev?.next = list2
                list2 = list2!.next
            }
            prev = prev?.next
        }

        prev?.next = (list1 != nil) ? list1 : list2

        return dummyNode.next
    }

OC

c 复制代码
//回溯法
- (ListNodeOC *_Nullable)mergeTwoLists:(ListNodeOC * _Nullable)list1
                        		 list2:(ListNodeOC * _Nullable)list2 {
    if (!list1) {
        return list2;
    }
    if (!list2) {
        return list1;
    }
    
    ListNodeOC *dummyNode = [[ListNodeOC alloc] initWithVal:-1];
    ListNodeOC *pre = dummyNode;
    
    while (list1 && list2) {
        if (list1.val < list2.val) {
            pre.next = list1;
            list1 = list1.next;
        }else {
            pre.next = list2;
            list2 = list2.next;
        }
        
        pre = pre.next;
    }
    
    pre.next = list1 ? list1 : list2;
    
    return dummyNode.next;
}

方法二、递归法

代码简洁、思路清晰、稍占内存的解法。

Swift

swift 复制代码
func mergeTwoLists(_ list1: ListNode?, _ list2: ListNode?) -> ListNode? {
        guard let list1 = list1 else { return list2 }
        guard let list2 = list2 else { return list1 }
        
        if list1.val < list2.val {
            list1.next = mergeTwoLists(list1.next, list2)
            return list1
        }else {
            list2.next = mergeTwoLists(list1, list2.next)
            return list2
        }
    }

OC

c 复制代码
//递归法
- (ListNodeOC * _Nullable)mergeTwoLists:(ListNodeOC * _Nullable)list1
                                  list2:(ListNodeOC * _Nullable)list2 {
    //递归终止条件
    if (!list1) {
        return list2;
    }
    if (!list2) {
        return list1;
    }
    
    if (list1.val < list2.val) {
        list1.next = [self mergeTwoLists:list1.next list2:list2];
        return list1;
    }else {
        list2.next = [self mergeTwoLists:list1 list2:list2.next];
        return list2;
    }
}
相关推荐
华阙之梦9 分钟前
【GIS课堂】
学习
知识分享小能手13 分钟前
MongoDB入门学习教程,从入门到精通,部署MongoDB(24)
数据库·学习·mongodb
m0_7167652323 分钟前
数据结构--循环链表、双向链表的插入、删除、查找详解
开发语言·数据结构·c++·学习·链表·青少年编程·visual studio
剑挑星河月27 分钟前
394.字符串解码
数据结构·算法·leetcode
愚昧之山绝望之谷开悟之坡33 分钟前
什么是SRE
笔记
油炸自行车1 小时前
Unity URDF 导入后运行报错问题笔记
笔记·unity·游戏引擎·数字孪生·urdf·工业仿真·虚拟与现实
南無忘码至尊1 小时前
Unity学习90天 - 第 5 天 - 阶段小项目
学习·unity·c#·游戏引擎
圣保罗的大教堂1 小时前
leetcode 3653. 区间乘法查询后的异或 I 中等
leetcode
圣保罗的大教堂1 小时前
leetcode 1848. 到目标元素的最小距离 简单
leetcode
YuanDaima20481 小时前
队列与单调队列基础原理与题目说明
人工智能·python·算法·leetcode·队列·手撕代码