leetcode 19 Remove Nth Node From End of List

本文介绍了一种高效的算法,用于在一次遍历中删除链表倒数第N个节点。通过使用两个指针,分别位于N步之遥的位置,可以找到待删除节点的前驱节点并进行删除操作。

Given a linked list, remove the nth node from the end of list and return its head.

For example,
Given linked list: 1->2->3->4->5, and n = 2.

After removing the second node from the end, the linked list becomes 1->2->3->5.

Note:
Given n will always be valid.
Try to do this in one pass.

解决方案:

Because the linked list have no knowledge about the previous nodes, we have to provide such information.

The difference between the final node and the to-be-delete node is N, hence we can utilize this information.
•front pointer points to the node which is N step away from the to-be-delete node
•rear pointer points to the to-be-delete node.

The algorithms is described as below:
•First driving front pointer N step forward.
•Secondly, move the 2 pointers 1 step ahead till the front pointer reach the end simultaneously, which will cause the rear pointer points to the previous node of the to-be-delete node.

Finally, jump the rear->next node by rear->next = rear->next->next.

下面的代码稍微有一个疑问:

http://bbs.youkuaiyun.com/topics/391029228

class Solution {
public:
    ListNode *removeNthFromEnd(ListNode *head, int n) {

        ListNode new_head(-1);
        new_head.next = head;

        ListNode *front = &new_head, *rear = &new_head;

        for (int i = 0; i < n; i++)
            front = front->next;

        while (front->next != NULL) {
            front = front->next;
            rear = rear->next;
        }

        ListNode *tmp = rear->next;
        rear->next = rear->next->next;
        delete tmp;

        head = new_head.next;

        return head;
    }
};

python解决方案:

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution:
    # @param {ListNode} head
    # @param {integer} n
    # @return {ListNode}
    def removeNthFromEnd(self, head, n):
        dummyHead = ListNode(0)
        dummyHead.next = head
        slow = fast = dummyHead

        for i in range(n):
            fast = fast.next

        while fast and fast.next:
            fast = fast.next
            slow = slow.next

        slow.next = slow.next.next

        return dummyHead.next
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

shiter

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值