【leetcode】Remove Nth Node From End of List

題目簡述:

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

For example,this

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.code

解題思路:

標準的雙指針,第一個指針先走n步,注意刪除時候的處理rem

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

class Solution:
    # @return a ListNode
    def removeNthFromEnd(self, head, n):
        posa = ListNode(0) 
        posa = head
        posb = ListNode(0)
        posb = head 
        pre = ListNode(0)
        pre.next = head
        while n > 0:
            posa = posa.next
            n -= 1
        while posa != None:
            #print 'a',posa.val
            #print 'b',posb.val
            posa = posa.next
            posb = posb.next
            pre = pre.next
        #print posb.val
        if pre.next == head:
            head = head.next
        else:
            pre.next = pre.next.next

        return head
相關文章
相關標籤/搜索