将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode() {}
* ListNode(int val) { this.val = val; }
* ListNode(int val, ListNode next) { this.val = val; this.next = next; }
* }
*/
class Solution {
public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
if(l1 == null){
return l2;
}
if(l2 == null){
return l1;
}
if (l1.val < l2.val){
l1.next = mergeTwoLists(l1.next,l2);
return l1;
}else{
l2.next = mergeTwoLists(l1,l2.next);
return l2;
}
}
}
这道题一开始真的没有什么思路 上手直接暴力求解,结果做了几次都是超出时间限制,后来学习了评论区的打印,自己回想了学习链表的知识,再加上递归的应用,勉勉强强做出来了。
这篇博客介绍了一种使用递归方法将两个已排序的链表合并成一个新链表的算法。博主在开始时遇到超时问题,但通过学习和实践,最终成功实现了高效解决方案。此算法适用于数据结构和链表操作的学习。
466

被折叠的 条评论
为什么被折叠?



