Remove Nth Node From End of List

Write a program to Remove Nth Node From End of List

Example 1:

Input: 5->2->8->4->1->NULL, n=3
Output:5->2->4->1->NULL

Approach:

Java

public class LinkListDeletionNthFEnd {
    public static void main(String[] args) {
        ListNode l = new ListNode(1);
        l.next = new ListNode(2);
        l.next.next = new ListNode(3);
        l.next.next.next = new ListNode(4);
        l.next.next.next.next = new ListNode(5);
        int n = 5;
        int length = linkedListLength(l);
        ListNode node = removetNthNodeFromEnd(l, n, length);
        System.out.println("After Removing :");
        linkedListTraversal(node);
    }

    private static void linkedListTraversal(ListNode node) {
        while (node != null) {
            System.out.print(node.val + " ");
            node = node.next;
        }
    }

    private static int linkedListLength(ListNode node) {
        int length = 0;

        while (node != null) {
            node = node.next;
            length++;
        }
        return length;
    }

    public static ListNode removetNthNodeFromEnd(ListNode headint nint length) {
        // If list is null
        if (head == null || n == 0) {
            return head;
        }
        // if delete first element
        // Base case
        if (n == length) {
            return head.next;
        }

        int count = 0;
        ListNode root = head;
        ListNode prev = head;

        while (root != null) {
            count++;
            // if found nth then delete
            if (count == length - n + 1) {
                prev.next = root.next;
                break;
            }
            // change previous
            prev = root;
            // head->next
            root = root.next;
        }
        return head;
    }
}

class ListNode {

    int val;
    ListNode next;

    ListNode() {
    }

    ListNode(int val) {
        this.val = val;
    }

    ListNode(int valListNode next) {
        this.val = val;
        this.next = next;
    }
}
// Time Complexity : O(n)
// Space Complexity : O(1)

C++

#include <bits/stdc++.h>
using namespace std;
//Struture of  node
struct Node
   int data;
   Node *next;
   Node(int data)
    {
        this->data=data;
        this->next=NULL;
    }
};

//function to traverse(print) a linked 
//list
void linkedListTraversal(Node *head)
{
    Node *temp=head;
    //iterate till we reach end of the linked 
    //list
    while(temp!=NULL)
     {
         //print the current
         //node data
         cout<<temp->data<<" ";
         //move to next node
         temp=temp->next;
     }
}

//function to find the length of
//inked list
int linkedListLength(Node* node
{
    int length = 0;

        while (node !=NULL) {
            node = node->next;
            length++;
        }
        return length;
}

//function to remove nth node
//from end of list
Node* removetNthNodeFromEnd(Node* headint nint length
{
    // If list is empty or n=0
        if (head ==NULL || n == 0) {
            return head;
        }
    // if delete first element
    // Base case
    if (n == length) {
            return head->next;
     }

    int count = 0;
    Noderoot = head;
    Nodeprev = head;

    while (root !=NULL) {
         count++;
            // if found nth then delete
         if (count == length - n + 1) {
                prev->next = root->next;
                free(root);
                break;
            }
            // change previous
            prev = root;
            // head->next
            root = root->next;
     }
        return head;
}
int main()
{
  Node *head=new Node(5);
  head->next=new Node(2);
  head->next->next=new Node(8);
  head->next->next->next=new Node(4);
  head->next->next->next->next=new Node(1);
  int length=linkedListLength(head);
  int n=3;
  head=removetNthNodeFromEnd(head,n,length);
  cout<<"After Removing \n";
  linkedListTraversal(head);
  return 0;
}

// Time Complexity : O(n)
// Space Complexity : O(1)


No comments:

Post a Comment