仅做学习笔记之用。
题目:
将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
示例 1:
输入:l1 = [1,2,4], l2 = [1,3,4] 输出:[1,1,2,3,4,4]
示例 2:
输入:l1 = [], l2 = [] 输出:[]
示例 3:
输入:l1 = [], l2 = [0] 输出:[0]
提示:
- 两个链表的节点数目范围是
[0, 50]
-100 <= Node.val <= 100
l1
和l2
均按 非递减顺序 排列
思路是这样的:
其实没什么好说的,大家上数据结构课的时候可能都已经做过这道题了。
就是定义两个结点,一个是用来返回的头结点,一个是当前遍历用的结点。
题目中方法传入两个链表,就判断如果两条链表都不为空,则判断它们当前的结点谁大谁小,因为已经说明了链表以非递减排列,甚至不用我们手动排序。小的就添加到当前遍历的结点,然后移到下一个,继续比对。直到其中一条链表没有结点时,就说明剩下的元素只有另一条链表,直接把剩下的结点接到当前遍历的后面就行。
代码如下:
/*** 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 head = new ListNode(0);ListNode current = head;while (l1 != null && l2 != null) {if (l1.val < l2.val) {current.next = l1;l1 = l1.next;} else {current.next = l2;l2 = l2.next;}current = current.next;}if (l1 != null) {current.next = l1;}if (l2 != null) {current.next = l2;}return head.next;}
}
(算法大佬英雄哪里出来曾曰:过——啦)
解决。