forked from TheAlgorithms/Java
-
Notifications
You must be signed in to change notification settings - Fork 0
/
SinglyLinkedList.java
224 lines (192 loc) · 4.94 KB
/
SinglyLinkedList.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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
package DataStructures.Lists;
/**
* This class implements a SinglyLinked List. This is done
* using SinglyLinkedList class and a LinkForLinkedList Class.
* <p>
* A linked list is similar to an array, it hold values.
* However, links in a linked list do not have indexes. With
* a linked list you do not need to predetermine it's size as
* it grows and shrinks as it is edited. This is an example of
* a singly linked list. Elements can only be added/removed
* at the head/front of the list.
*/
public class SinglyLinkedList {
/**
* Head refer to the front of the list
*/
private Node head;
/**
* size of SinglyLinkedList
*/
private int size;
/**
* init SinglyLinkedList
*/
public SinglyLinkedList() {
head = new Node(0);
size = 0;
}
/**
* This method inserts an element at the head
*
* @param x Element to be added
*/
public void insertHead(int x) {
insertNth(x, 0);
}
/**
* insert an element at the tail of list
*
* @param data Element to be added
*/
public void insert(int data) {
insertNth(data, size);
}
/**
* Inserts a new node at a specified position
*
* @param data data to be stored in a new node
* @param position position at which a new node is to be inserted
*/
public void insertNth(int data, int position) {
checkBounds(position, 0, size);
Node cur = head;
for (int i = 0; i < position; ++i) {
cur = cur.next;
}
Node node = new Node(data);
node.next = cur.next;
cur.next = node;
size++;
}
/**
* This method deletes an element at the head
*
* @return The element deleted
*/
public void deleteHead() {
deleteNth(0);
}
/**
* This method deletes an element at the tail
*/
public void delete() {
deleteNth(size - 1);
}
/**
* This method deletes an element at Nth position
*/
public void deleteNth(int position) {
checkBounds(position, 0, size - 1);
Node cur = head;
for (int i = 0; i < position; ++i) {
cur = cur.next;
}
Node destroy = cur.next;
cur.next = cur.next.next;
destroy = null; // clear to let GC do its work
size--;
}
/**
* @param position to check position
* @param low low index
* @param high high index
* @throws IndexOutOfBoundsException if {@code position} not in range {@code low} to {@code high}
*/
public void checkBounds(int position, int low, int high) {
if (position < low || position > high) {
throw new IndexOutOfBoundsException(position + "");
}
}
/**
* clear all nodes in list
*/
public void clear() {
if (size == 0) {
return;
}
Node prev = head.next;
Node cur = prev.next;
while (cur != null) {
prev = null; // clear to let GC do its work
prev = cur;
cur = cur.next;
}
prev = null;
head.next = null;
size = 0;
}
/**
* Checks if the list is empty
*
* @return true is list is empty
*/
public boolean isEmpty() {
return size == 0;
}
/**
* Returns the size of the linked list
*/
public int getSize() {
return size;
}
@Override
public String toString() {
if (size == 0) {
return "";
}
StringBuilder builder = new StringBuilder();
Node cur = head.next;
while (cur != null) {
builder.append(cur.value).append("->");
cur = cur.next;
}
return builder.replace(builder.length() - 2, builder.length(), "").toString();
}
/**
* Main method
*
* @param args Command line arguments
*/
public static void main(String args[]) {
SinglyLinkedList myList = new SinglyLinkedList();
assert myList.isEmpty();
myList.insertHead(5);
myList.insertHead(7);
myList.insertHead(10);
System.out.println(myList);; // 10 -> 7 -> 5
myList.deleteHead();
System.out.println(myList);; // 7 -> 5
myList.insertNth(11, 2);
System.out.println(myList);; // 7 -> 5 -> 11
myList.deleteNth(1);
System.out.println(myList);; // 7-> 11
myList.clear();
assert myList.isEmpty();
System.out.println(myList); // ""
}
}
/**
* This class is the nodes of the SinglyLinked List.
* They consist of a value and a pointer to the node
* after them.
*/
class Node {
/**
* The value of the node
*/
int value;
/**
* Point to the next node
*/
Node next;
/**
* Constructor
*
* @param value Value to be put in the node
*/
Node(int value) {
this.value = value;
this.next = null;
}
}