-
Notifications
You must be signed in to change notification settings - Fork 32
/
Copy path0206-reverse-linked-list.rs
52 lines (42 loc) · 1.46 KB
/
0206-reverse-linked-list.rs
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
/*
Problem: LeetCode 206 - Reverse Linked List
Key Idea:
The key idea is to reverse the linked list by iteratively changing the direction of the pointers.
Approach:
1. Initialize three pointers: `prev` as `None`, `curr` as the head of the linked list, and `next` as `None`.
2. Iterate through the linked list:
- Save the next node of `curr` in `next`.
- Update the `next` pointer of `curr` to point to the `prev` node (reverse the direction).
- Move `prev` to `curr` and `curr` to `next`.
3. After the loop, `prev` will be the new head of the reversed linked list.
4. Return `prev` as the new head.
Time Complexity:
O(n), where n is the number of nodes in the linked list. We perform a single pass through the linked list.
Space Complexity:
O(1), as we use a constant amount of extra space for the three pointers.
*/
// Definition for singly-linked list
// #[derive(PartialEq, Eq, Clone, Debug)]
// pub struct ListNode {
// pub val: i32,
// pub next: Option<Box<ListNode>>,
// }
// impl ListNode {
// #[inline]
// fn new(val: i32) -> Self {
// ListNode { next: None, val }
// }
// }
impl Solution {
pub fn reverse_list(head: Option<Box<ListNode>>) -> Option<Box<ListNode>> {
let mut prev = None;
let mut curr = head;
while let Some(mut node) = curr.take() {
let next = node.next.take();
node.next = prev.take();
prev = Some(node);
curr = next;
}
prev
}
}