Skip to content

Latest commit

 

History

History
45 lines (35 loc) · 764 Bytes

File metadata and controls

45 lines (35 loc) · 764 Bytes

Reverse Linked List

Reverse a singly linked list.

click to show more hints. Hint:

A linked list can be reversed either iteratively or recursively. Could you implement both?

Solution

迭代法:

ListNode *reverseIteratively(ListNode *head) {
	if (!head || !head->next)
		return head;
	ListNode *prev = nullptr, *p = head;
	while (p) {
		ListNode *q = p->next;
		p->next = prev;
		prev = p;
		p = q;
	}
	return prev;
}

递归法,注意更新head指针:

ListNode *reverseRecursively(ListNode *&head, ListNode *p) {
	if (!p|| !p->next) {
		head = p;
		return head;
	}
	reverseRecursively(head, p->next)->next = p;
	p->next = nullptr;
	return p;
}

扩展

Reverse Linked List II: 逆转指定的区间