LeetCode 21. Merge Two Sorted Lists
Merge two sorted linked lists and return it as a new list. The new list should be made by splicing together the nodes of the first two lists.
public class MergeTwoSortedListsSolution {
/**
* 解法一
*/
public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
//常規解法:利用迴圈
ListNode result = null;//頭指標
ListNode now = result;//尾指標
while (l1 != null && l2 != null) {
ListNode temp = null;
if (l1.val > l2.val) {
temp = l2;
l2 = l2.next;
} else {
temp = l1;
l1 = l1.next;
}
temp.next = null;
if (result != null) {
now.next = temp;
now = now.next;
} else {
result = temp;
now = result;
}
}
if (now != null) {
if (l1 != null) {
now.next = l1;
}
if (l2 != null) {
now.next = l2;
}
} else {
if (l1 != null) {
return l1;
}
if (l2 != null) {
return l2;
}
}
return result;
}
/**
* 解法二
*/
public ListNode merge(ListNode l1, ListNode l2) {
/**
* 遞迴解法
* 遞迴邊界:l1==null,l2==null
* 每遞迴一次問題向下求解一次
*
*/
if (l1 == null) return l2;
if (l2 == null) return l1;
if (l1.val < l2.val) {
l1.next = merge(l1.next, l2);
return l1;
} else {
l2.next = merge(l1, l2.next);
return l2;
}
}
}
相關文章
- Leetcode 21 Merge Two Sorted ListsLeetCode
- LeetCode Merge Two Sorted Lists(021)解法總結LeetCode
- Leetcode 23 Merge k Sorted ListsLeetCode
- 【Leetcode】23. Merge k Sorted ListsLeetCode
- 資料結構與演算法 | Leetcode 21:Merge Two Sorted Lists資料結構演算法LeetCode
- Merge Two Sorted List
- Leetcode 160. Intersection of Two Linked ListsLeetCode
- Leetcode 4 Median of Two Sorted ArraysLeetCode
- Leetcode 88. Merge Sorted ArrayLeetCode
- LeetCode 4. Median of Two Sorted ArraysLeetCode
- LeetCode 之 JavaScript 解答第23題 —— 合併K個有序連結串列(Merge K Sorted Lists)LeetCodeJavaScript
- 【LeetCode】617. Merge Two Binary TreesLeetCode
- LeetCode 617. Merge Two Binary TreesLeetCode
- LeetCode Median of Two Sorted Arrays(004)解法總結LeetCode
- 【Leetcode】167. Two Sum II - Input array is sortedLeetCode
- Fourth. LeetCode 21:MergeTwo Sorted Lists 合併兩個有序連結串列LeetCode
- 88. Merge Sorted Array
- 617-Merge Two Binary Trees
- Leetcode 231 Power of TwoLeetCode
- Leetcode 1 two sumLeetCode
- LeetCode | 1 Two SumLeetCode
- Leetcode 29 Divide Two IntegersLeetCodeIDE
- LeetCode 2 Add Two NumbersLeetCode
- LeetCode-1 Two SumLeetCode
- [LeetCode]1.Two SumLeetCode
- LeetCode | 349 Intersection Of Two ArraysLeetCode
- Leetcode 231. Power of TwoLeetCode
- python: leetcode - 1 Two SumPythonLeetCode
- Leetcode 33 Search in Rotated Sorted ArrayLeetCode
- LeetCode之Squares of a Sorted Array(Kotlin)LeetCodeKotlin
- [LeetCode] 721. Accounts MergeLeetCode
- Python, pandas: how to sort dataframe by index// Merge two dataframes by indexPythonIndex
- leetcode 4. Median of Two Sorted Arrays 尋找兩個正序陣列的中位數(困難)LeetCode陣列
- leetcode-29. Divide Two IntegersLeetCodeIDE
- LeetCode-2 Add Two NumbersLeetCode
- LeetCode: Two sum(兩數之和)LeetCode
- [LeetCode] 29. Divide Two IntegersLeetCodeIDE
- LeetCode 2. Add Two NumbersLeetCode