首页 > 代码库 > LeetCode[Linked List]: Reverse Linked List II
LeetCode[Linked List]: Reverse Linked List II
Reverse a linked list from position m to n. Do it in-place and in one-pass.
For example:
Given1->2->3->4->5->NULL
, m = 2 and n = 4,
return1->4->3->2->5->NULL
.
Note:
Given m, n satisfy the following condition:1 ≤ m ≤ n ≤ length of list
.
思路很简单:设置两个指针:fast往前移动n步,low往前移动m步,然后依次将low和fast之间的节点挨个插到fast的后面即可。注意:为去除头结点的特殊性,需要用到虚拟头结点技术。
ListNode *reverseBetween(ListNode *head, int m, int n) {
ListNode *dummyHead = new ListNode(0);
dummyHead->next = head;
ListNode *fast = head;
for (int i = 0; i < n - 1; ++i)
fast = fast->next;
ListNode *low = dummyHead;
for (int i = 0; i < m - 1; ++i)
low = low ->next;
for (int i = 0; i < n - m; ++i) {
ListNode *curr = low->next;
low ->next = low ->next->next;
curr->next = fast->next;
fast->next = curr;
}
head = dummyHead->next;
delete dummyHead;
return head;
}
LeetCode[Linked List]: Reverse Linked List II
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。