public class Test {
public static void main(String[] args) {
SinglyLinkedList list = new SinglyLinkedList(); // {null}
list.insertToHead(5); // {5} -> {null}
list.insertToTail(1); // {5} -> {1} -> {null}
list.insertToHead(2); // {2} -> {5} -> {1} -> {null}
list.insertToTail(3); // {2} -> {5} -> {1} -> {3} -> {null}
list.deleteTail();
list.deleteTail();
list.deleteTail();
list.deleteTail();
list.traverse();
}
}
class SinglyLinkedList {
Node head;
void insertToHead(int value) {
Node newNode = new Node();
newNode.data = value;
newNode.next = head;
head = newNode;
}
void insertToTail(int value) {
Node newNode = new Node();
newNode.data = value;
if (head == null){
head = newNode;
} else {
Node temp = head;
while (temp.next != null) {
temp = temp.next;
}
temp.next = newNode;
}
}
void insertAt(int data) {
}
void deleteHead() {
if (head != null) {
head = head.next;
}
}
void deleteTail() {
if (head == null) {
// wala
} else if (head.next == null) {
head = null;
} else {
Node temp = head;
Node prev = null;
while (temp.next != null) {
prev = temp;
temp = temp.next;
}
prev.next = null;
}
}
void deleteAt() {
}
void traverse() {
Node temp = head;
while (temp != null) {
System.out.println(temp.data);
temp = temp.next;
}
}
}
class Node {
int data;
Node next;
}