网站首页 > java教程 正文
题目:
将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
示例:
输入:1->2->5, 0->3->4
输出:0->1->2->3->4->5
实现思路:
我们可以如下递归地定义在两个链表里的 merge 操作(忽略边界情况,比如空链表等):
{
list1[0]+merge(list1[1:],list2)
list2[0]+merge(list1,list2[1:])
?
list1[0]<list2[0]
otherwise
?
也就是说,两个链表头部较小的一个与剩下元素的 merge 操作结果合并。
算法:
我们直接将以上递归过程建模,首先考虑边界情况。
特殊的,如果 l1 或者 l2 一开始就是 null ,那么没有任何操作需要合并,所以我们只需要返回非空链表。否则,我们要判断 l1 和 l2 哪一个的头元素更小,然后递归地决定下一个添加到结果里的值。如果两个链表都是空的,那么过程终止,所以递归过程最终一定会终止。
如下是图解:
递归实现如下:
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) { val = x; }
* }
*/
class Solution {
public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
if(l1 == null || l2 == null){
return l1!=null?l1:l2;
}
if(l1.val <l2.val){
l1.next = mergeTwoLists(l1.next,l2);
return l1;
}
else{
l2.next = mergeTwoLists(l1,l2.next);
return l2;
}
}
}
猜你喜欢
- 2024-12-31 删除链表中重复的节点
- 2024-12-31 LeetCode每日一题,合并K个升序链表
- 2024-12-31 面试必问-JAVA-LRU-双向链表+HashMap方式实现
- 2024-12-31 两个有序链表的合并
- 2024-12-31 【约瑟夫环】C语言数组法+java循环链表法
- 2024-12-31 Java手写单向链表
- 2024-12-31 java判断链表是否有环(两种方式实现)
- 2024-12-31 JAVA 反转链表
- 2024-12-31 算法篇:图解双向链表及Java实现
- 2024-12-31 剑指Offer (十五):反转链表(Java版)
你 发表评论:
欢迎- 04-24Java Collections 工具类集合框架中常用算法解析
- 04-24桶排序的简单理解
- 04-24Java集合框架底层实现原理大揭秘
- 04-24Java 集合框架全面解析:选对数据结构,提升开发效率
- 04-24c#集合排序
- 04-24Java面试中常被问到的集合类深度解读
- 04-24VBA技术资料MF278:对集合进行排序
- 04-24Spring 最常用的 7 大类注解,史上最强整理
- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)