/
Remove_duplicates_from_an_unsorted.java
84 lines (73 loc) · 1.62 KB
/
Remove_duplicates_from_an_unsorted.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
import java.util.*;
class Node {
int data;
Node next;
Node(int d) {
data = d;
next = null;
}
}
class Remove_Duplicate_From_LL {
Node head;
Node temp;
public void addToTheLast(Node node) {
if (head == null) {
head = node;
temp = node;
} else {
temp.next = node;
temp = node;
}
}
void printList() {
Node temp = head;
while (temp != null) {
System.out.print(temp.data + " ");
temp = temp.next;
}
System.out.println();
}
/* Drier program to test above functions */
public static void main(String args[]) {
/*
* Constructed Linked List is 1->2->3->4->5->6->
* 7->8->8->9->null
*/
Scanner sc = new Scanner(System.in);
int t = sc.nextInt();
while (t > 0) {
int n = sc.nextInt();
Remove_Duplicate_From_LL llist = new Remove_Duplicate_From_LL();
int a1 = sc.nextInt();
Node head = new Node(a1);
llist.addToTheLast(head);
for (int i = 1; i < n; i++) {
int a = sc.nextInt();
llist.addToTheLast(new Node(a));
}
// llist.printList();
Solution g = new Solution();
llist.head = g.removeDuplicates(llist.head);
llist.printList();
t--;
}
}
}
class Solution {
public Node removeDuplicates(Node head) {
HashSet<Integer> set = new HashSet<>();
Node curr = head;
Node next = head.next;
set.add(head.data);
while (next != null) {
if (!set.contains(next.data)) {
set.add(next.data);
curr.next = next;
curr = curr.next;
}
next = next.next;
}
curr.next = null;
return head;
}
}