-
Notifications
You must be signed in to change notification settings - Fork 518
/
Copy pathMergeSortedLists.cpp
37 lines (32 loc) · 1.05 KB
/
MergeSortedLists.cpp
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
27
28
29
30
31
32
33
34
35
36
37
#include <bits/stdc++.h>
using namespace std;
// Definition for singly-linked list.
struct ListNode {
int val;
ListNode *next;
ListNode() : val(0), next(nullptr) {}
ListNode(int x) : val(x), next(nullptr) {}
ListNode(int x, ListNode *next) : val(x), next(next) {}
};
class Solution {
public:
// Merges two sorted linked lists
ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) {
ListNode *dummy = new ListNode(); // Placeholder node
ListNode *ptr = dummy; // Pointer to build merged list
// Compare nodes from both lists
while (list1 && list2) {
if (list1->val < list2->val) {
ptr->next = list1; // Add smaller node
list1 = list1->next;
} else {
ptr->next = list2;
list2 = list2->next;
}
ptr = ptr->next;
}
// Append remaining nodes
ptr->next = list1 ? list1 : list2;
return dummy->next; // Return merged list (skip dummy)
}
};