合并两个排序的链表

题目描述

输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。

解题思路

  • 使用递归即可,比较链表 A 与链表 B 的首结点,如 A > B ,则 B 的首结点为最小,接下来 B.next 与 A 的首结点比较,不断重复此过程即可。

代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
/*
public class ListNode {
int val;
ListNode next = null;

ListNode(int val) {
this.val = val;
}
}*/
public class Solution {
public ListNode Merge(ListNode list1,ListNode list2) {
if(list1 == null){
return list2;
}
if(list2 == null){
return list1;
}
if(list1.val > list2.val){
list2.next = Merge(list1, list2.next);
return list2;
}else{
list1.next = Merge(list1.next, list2);
return list1;
}
}
}
坚持原创技术分享,您的支持将鼓励我继续创作!