【注释详细,思路清晰】【打卡第10天】leetcode热题HOT100之Java实现:21. 合并两个有序链表
2021/7/12 11:08:10
本文主要是介绍【注释详细,思路清晰】【打卡第10天】leetcode热题HOT100之Java实现:21. 合并两个有序链表,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1、题目描述
将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
2、算法分析
① 先创建一个空的链表存储结果集
② 比较l1,l2的值,然后存储到链表中
③ 如果其中一个链表为空,结果集指针链接另一个链表
④ 返回链表的头结点
关于ListNode node = new ListNode(x);的详解,请访问:
https://blog.csdn.net/Sunshineoe/article/details/110371832
3、代码实现
/** * 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) { // 定义一个空的链表 ListNode dummy = new ListNode(0); // 定义一个指针指向的是当前结点 ListNode current = dummy; while(l1 != null && l2 != null){ if(l1.val < l2.val){ current.next = l1; current = current.next; l1 = l1.next; }else{ current.next = l2; current = current.next; l2 = l2.next; } } if(l1 == null){ current.next = l2; } if(l2 == null){ current.next = l1; } return dummy.next; } }
这篇关于【注释详细,思路清晰】【打卡第10天】leetcode热题HOT100之Java实现:21. 合并两个有序链表的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-01一个基于注解驱动的可视化的DDD架构-超越COLA的设计
- 2025-01-01PlantUML 时序图 基本例子
- 2025-01-01plantuml 信号时序图
- 2025-01-01聊聊springboot项目如何优雅进行数据校验
- 2024-12-31自由职业者效率提升指南:3个时间管理技巧搞定多个项目
- 2024-12-31适用于咨询行业的项目管理工具:提升跨团队协作和工作效率的最佳选择
- 2024-12-31高效协作的未来:2024年实时文档工具深度解析
- 2024-12-31商务谈判者的利器!哪 6 款办公软件能提升春节合作成功率?
- 2024-12-31小团队如何选择最实用的项目管理工具?高效协作与任务追踪指南
- 2024-12-31数据赋能,智慧养老:看板软件如何重塑养老服务生态