前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >leetcode 19 Remove Nth Node From End of List

leetcode 19 Remove Nth Node From End of List

作者头像
流川疯
发布2019-01-18 14:48:11
2900
发布2019-01-18 14:48:11
举报

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.csdn.net/topics/391029228

代码语言:javascript
复制
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解决方案:

代码语言:javascript
复制
# 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
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2015年05月05日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档