Skip to content

Latest commit

 

History

History

3.7 Remove Nth From End Of Linkded List

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 

Remove Nth From End Of Linkded List (删除倒数第N个节点)

From

LeetCode 19

Question

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

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.

Solution

C++

struct ListNode {
    int val;
    ListNode *next;
    ListNode(int x) : val(x), next(NULL) {}
};
 
class Solution {
public:
    
    ListNode *removeNthFromEnd(ListNode *head, int n) {
        
        if( head == NULL || head->next == NULL){
            return NULL;
        }
        
        ListNode * firstNode = head;
        ListNode * secondNode = head;
        
        for(int i = 0;i < n; i++){
            firstNode = firstNode->next;
        }
        
        //1,2,3,4,5 n = 4
        if(firstNode == NULL){
            return head->next;
        }
        
        while(firstNode->next != NULL)
        {
            firstNode = firstNode->next;
            secondNode = secondNode->next;
        }
        
        secondNode->next = secondNode->next->next;
        
        return head;
    }
    
};

Java

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {
        
       if( head == null || head.next == null){
            return null;
        }
        
        ListNode firstNode = head;
        ListNode secondNode = head;
        
        for(int i = 0; i < n; i++){
            firstNode = firstNode.next;
        }
        
        //1,2,3,4,5 n = 4
        if(firstNode == null){
            return head.next;
        }
        
        while(firstNode.next != null)
        {
            firstNode = firstNode.next;
            secondNode = secondNode.next;
        }
        
        secondNode.next = secondNode.next.next;
        
        return head;
        
    }
}