【LeetCode】合并两个有序链表 Java 题解
题目描述
将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
复制代码
思路分析
今天的算法每日一题,是合并有序链表题目,也是非常常见的一类入门题目。题目要求将两个升序链表合并为一个新的 升序 链表并返回。
根据题目要求,我们可以采用递归的算法思想解决问题,链表的递归终止条件是 node == null, 然后分别比较链表值的大小进行排序。
这个题目也可以采用迭代的算法解决,定义一个 dummy 节点,辅助操作链表。实现代码如下:
通过代码
递归算法
复制代码
迭代算法
复制代码
总结
上述代码的时间复杂度是 O(n),空间复杂度是 O(n)
坚持算法每日一题,加油!
版权声明: 本文为 InfoQ 作者【HQ数字卡】的原创文章。
原文链接:【http://xie.infoq.cn/article/6c911da7de2fae268ff399ee9】。文章转载请联系作者。
评论