From d8758869acc86ed707f515490efdad5b86198ac0 Mon Sep 17 00:00:00 2001 From: Nishant Dwivedi <135944619+nishant4500@users.noreply.github.com> Date: Sun, 10 Nov 2024 11:50:03 +0530 Subject: [PATCH] Update remove-duplicates-from-sorted-list.md --- .../remove-duplicates-from-sorted-list.md | 77 ++++++++++++++++++- 1 file changed, 76 insertions(+), 1 deletion(-) diff --git a/docs/linked-list/remove-duplicates-from-sorted-list.md b/docs/linked-list/remove-duplicates-from-sorted-list.md index 54dfc4b6a..e13895521 100644 --- a/docs/linked-list/remove-duplicates-from-sorted-list.md +++ b/docs/linked-list/remove-duplicates-from-sorted-list.md @@ -117,4 +117,79 @@ int main() { return 0; } -``` \ No newline at end of file +``` +## Code Implementation + +Here’s the JAVA code for removing duplicates from a sorted linked list: +```java +import java.util.*; + +class ListNode { + int val; + ListNode next; + ListNode(int x) { + val = x; + next = null; + } +} + +class Solution { + public ListNode deleteDuplicates(ListNode head) { + if (head == null) return null; // If list is empty, return null + + ListNode current = head; // Start with the head of the list + + // Traverse the list + while (current != null && current.next != null) { + if (current.val == current.next.val) { + // Skip the duplicate node + current.next = current.next.next; + } else { + // Move to the next distinct element + current = current.next; + } + } + + return head; // Return the modified list without duplicates + } +} + +// Helper function to create a linked list from an array +public class LinkedListUtils { + public static ListNode createLinkedList(int[] values) { + ListNode dummy = new ListNode(0); + ListNode current = dummy; + for (int value : values) { + current.next = new ListNode(value); + current = current.next; + } + return dummy.next; + } + + // Helper function to print a linked list + public static void printLinkedList(ListNode head) { + ListNode current = head; + while (current != null) { + System.out.print(current.val); + if (current.next != null) System.out.print(" -> "); + current = current.next; + } + System.out.println(); + } + + public static void main(String[] args) { + int[] listValues = {1, 1, 2}; + ListNode head = createLinkedList(listValues); + + System.out.print("Original List: "); + printLinkedList(head); + + Solution solution = new Solution(); + ListNode modifiedHead = solution.deleteDuplicates(head); + + System.out.print("List after removing duplicates: "); + printLinkedList(modifiedHead); + } +} + +```