网站首页 > 技术文章 正文
题目
将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
解题思路
从题目和示例可以看出,应该是要循环遍历链表进行比较,然后组成新的链表。
第一种:递归
第二种:迭代
解题过程
第一种:递归
1、先判断两个链表是否为空,如果list1为空,则返回list2,如果list2为空,则返回list1。
2、如果都不为空,递归比较每个节点大小,直到最后一个节点。
/**
* 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 list1, ListNode list2) {
if (list1 == null) {
return list2;
} else if (list2 == null) {
return list1;
} else if (list1.val < list2.val) {
list1.next = mergeTwoLists(list1.next, list2);
return list1;
} else {
list2.next = mergeTwoLists(list1, list2.next);
return list2;
}
}
}
第二种:迭代
1、先判断两个链表是否为空,如果list1为空,则返回list2; 如果list2为空,则返回list1。
2、其次创建新的链表,作为整个链表的头部head,再创建一个nextNode用于指向下一个节点,比较list1和list2的每个节点,将较小的节点赋值给nextNode。
3、最后返回head.next,即为新的链表。
/**
* 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 list1, ListNode list2) {
if (list1 == null) {
return list2;
} else if (list2 == null) {
return list1;
}
ListNode head = new ListNode(-1);
ListNode nextNode = head;
while (list1 != null && list2 != null) {
if(list1.val < list2.val) {
nextNode.next = list1;
list1 = list1.next;
} else {
nextNode.next = list2;
list2 = list2.next;
}
nextNode = nextNode.next;
}
nextNode.next = list1 == null ? list2 : list1;
return head.next;
}
}
- 上一篇: java使用ByteBuffer并进行多文件合并和拆分
- 下一篇:已经是最后一篇了
猜你喜欢
- 2024-11-25 Java中对于+和append拼接字符串效率的误解
- 2024-11-25 java使用ByteBuffer并进行多文件合并和拆分
- 2024-11-25 2020-12-17:java和go,如何高效的拼接字符串?
- 2024-11-25 Java字符串拼接技术演进及阿里巴巴的贡献
- 2024-11-25 如何提升Jmeter操作?那你一定得学会BeanShell
- 2024-11-25 Java 字符串拼接 五种方法的性能比较分析
- 2024-11-25 Java合并两个数组,以及数组排序并去重
- 2024-11-25 Java Stream 流如何进行合并操作
- 2024-11-25 Java请求合并与分而治之
- 2024-11-25 大厂面试-Java中字符串拼接有几种方式?
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)