反转链表
定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。
示例:
输入: 1->2->3->4->5->NULL
输出: 5->4->3->2->1->NULL
1
2
2
限制:
0 <= 节点个数 <= 5000
// 迭代
// 时间复杂度O(n)
// 空间复杂度O(1)
var reverseList = function(head) {
let prev = null
let curr = head
while(curr) {
const next = curr.next
curr.next = prev
prev = curr
curr = next
}
return prev
};
// 递归
// 时间复杂度O(n)
// 空间复杂度O(n)
var reverseList = function (head) {
if (head === null || head.next === null) return head;
const newHead = reverseList(head.next);
head.next.next = head;
head.next = null;
return newHead;
};
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
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
上次更新: 2022/09/15, 17:09:42