The LinkedList class extends AbstractSequentialList. This AbstractSequentialList class extends AbstractList.AbstractList implements the List interface. LinkedList class finally implements the List interface. LinkedList class has the two constructors;
1.LinkedList()
ex: LinkedList ll=new LinkedList();
2.LinkedList(Collection c)
The first constructor builds an empty linked list.
The second constructor builds a linked list that is initialized with the elements of the collection c.
The LinkedList class defines some useful methods of its own for manipulating and accessing lists.
To add elements to the start of the list, use
public void addFirst(Object o)
ex: ll.addFirst(new Integer(10));
To add elements to the end, use
public void addLast(Object o)
Here, 'o' is the item being added.
ex: ll.addLast(new Integer(10));
To obtain the first element, use
public Object getFirst()
ex: Object o= ll.getFirst();
To obtain the last element, use
public Object getLast()
ex: Object o= ll.getLast();
To remove the first element, use
public Object removeFirst()
ex: Object o= ll.removeFirst();
To remove the last element, use
public Object removeLast()
ex: Object o= ll.removeLast();
To insert items at a specific location, use
public void add(int, Object)
ex: ll.add(1, "A2")
To get items at a specific location, use
public Object get(int)
ex: Object o=ll.get(1);
To remove items at a specific location, use
public Object remove(int)
ex: Object o=ll.remove(1);
import java.util.*;
public class LinkedListExample
{
public static void main(String[] args)
{
System.out.println("Linked List Example!");
LinkedList list = new LinkedList();
int size;
Iterator iterator;
//Adding data in the list
list.add(new Integer(11));
list.add(new Integer(22));
list.add(new Integer(33));
list.add(new Integer(44));
size = list.size();
System.out.print( "Linked list data: ");
//Create a iterator
iterator = list.iterator();
while (iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println();
//Check list empty or not
if (list.isEmpty()){
System.out.println("Linked list is empty");
}
else{
System.out.println( "Linked list size: " + size);
}
System.out.println("Adding data at 1st location: 55");
//Adding first
list.addFirst(new Integer(55));
System.out.print("Now the list contain: ");
iterator = list.iterator();
while (iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println();
System.out.println("Now the size of list: " + list.size());
System.out.println("Adding data at last location: 66");
//Adding last or append
list.addLast(new Integer(66));
System.out.print("Now the list contain: ");
iterator = list.iterator();
while (iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println();
System.out.println("Now the size of list: " + list.size());
System.out.println("Adding data at 3rd location: 99");
//Adding data at 3rd position
list.add(2,new Integer(99));
System.out.print("Now the list contain: ");
iterator = list.iterator();
while (iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println();
System.out.println("Now the size of list: " + list.size());
//Retrieve first data
System.out.println("First data: " + list.getFirst());
//Retrieve lst data
System.out.println("Last data: " + list.getLast());
//Retrieve specific data
System.out.println("Data at 4th position: " + list.get(3));
//Remove first
int first = list.removeFirst();
System.out.println("Data removed from 1st location: " + first);
System.out.print("Now the list contain: ");
iterator = list.iterator();
//After removing data
while (iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println();
System.out.println("Now the size of list: " + list.size());
//Remove last
int last = list.removeLast();
System.out.println("Data removed from last location: " + last);
System.out.print("Now the list contain: ");
iterator = list.iterator();
//After removing data
while (iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println();
System.out.println("Now the size of list: " + list.size());
//Remove 2nd data
int second = list.remove(1);
System.out.println("Data removed from 2nd location: " + second);
System.out.print("Now the list contain: ");
iterator = list.iterator();
//After removing data
while (iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println();
System.out.println("Now the size of list: " + list.size());
//Remove all
list.clear();
if (list.isEmpty()){
System.out.println("Linked list is empty");
}
else{
System.out.println( "Linked list size: " + size);
}
}
}
Output:
LinkedListExample
Linked List Example!
Linked list data: 11 22 33 44
Linked list size: 4
Adding data at 1st location: 55
Now the list contain: 55 11 22 33 44
Now the size of list: 5
Adding data at last location: 66
Now the list contain: 55 11 22 33 44 66
Now the size of list: 6
Adding data at 3rd location: 55
Now the list contain: 55 11 99 22 33 44 66
Now the size of list: 7
First data: 55
Last data: 66
Data at 4th position: 22
Data removed from 1st location: 55
Now the list contain: 11 99 22 33 44 66
Now the size of list: 6
Data removed from last location: 66
Now the list contain: 11 99 22 33 44
Now the size of list: 5
Data removed from 2nd location: 99
Now the list contain: 11 22 33 44
Now the size of list: 4
Linked list is empty
ex: LinkedList ll=new LinkedList();
2.LinkedList(Collection c)
The first constructor builds an empty linked list.
The second constructor builds a linked list that is initialized with the elements of the collection c.
The LinkedList class defines some useful methods of its own for manipulating and accessing lists.
To add elements to the start of the list, use
public void addFirst(Object o)
ex: ll.addFirst(new Integer(10));
To add elements to the end, use
public void addLast(Object o)
Here, 'o' is the item being added.
ex: ll.addLast(new Integer(10));
To obtain the first element, use
public Object getFirst()
ex: Object o= ll.getFirst();
To obtain the last element, use
public Object getLast()
ex: Object o= ll.getLast();
To remove the first element, use
public Object removeFirst()
ex: Object o= ll.removeFirst();
To remove the last element, use
public Object removeLast()
ex: Object o= ll.removeLast();
To insert items at a specific location, use
public void add(int, Object)
ex: ll.add(1, "A2")
To get items at a specific location, use
public Object get(int)
ex: Object o=ll.get(1);
To remove items at a specific location, use
public Object remove(int)
ex: Object o=ll.remove(1);
import java.util.*;
public class LinkedListExample
{
public static void main(String[] args)
{
System.out.println("Linked List Example!");
LinkedList list = new LinkedList();
int size;
Iterator iterator;
//Adding data in the list
list.add(new Integer(11));
list.add(new Integer(22));
list.add(new Integer(33));
list.add(new Integer(44));
size = list.size();
System.out.print( "Linked list data: ");
//Create a iterator
iterator = list.iterator();
while (iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println();
//Check list empty or not
if (list.isEmpty()){
System.out.println("Linked list is empty");
}
else{
System.out.println( "Linked list size: " + size);
}
System.out.println("Adding data at 1st location: 55");
//Adding first
list.addFirst(new Integer(55));
System.out.print("Now the list contain: ");
iterator = list.iterator();
while (iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println();
System.out.println("Now the size of list: " + list.size());
System.out.println("Adding data at last location: 66");
//Adding last or append
list.addLast(new Integer(66));
System.out.print("Now the list contain: ");
iterator = list.iterator();
while (iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println();
System.out.println("Now the size of list: " + list.size());
System.out.println("Adding data at 3rd location: 99");
//Adding data at 3rd position
list.add(2,new Integer(99));
System.out.print("Now the list contain: ");
iterator = list.iterator();
while (iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println();
System.out.println("Now the size of list: " + list.size());
//Retrieve first data
System.out.println("First data: " + list.getFirst());
//Retrieve lst data
System.out.println("Last data: " + list.getLast());
//Retrieve specific data
System.out.println("Data at 4th position: " + list.get(3));
//Remove first
int first = list.removeFirst();
System.out.println("Data removed from 1st location: " + first);
System.out.print("Now the list contain: ");
iterator = list.iterator();
//After removing data
while (iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println();
System.out.println("Now the size of list: " + list.size());
//Remove last
int last = list.removeLast();
System.out.println("Data removed from last location: " + last);
System.out.print("Now the list contain: ");
iterator = list.iterator();
//After removing data
while (iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println();
System.out.println("Now the size of list: " + list.size());
//Remove 2nd data
int second = list.remove(1);
System.out.println("Data removed from 2nd location: " + second);
System.out.print("Now the list contain: ");
iterator = list.iterator();
//After removing data
while (iterator.hasNext()){
System.out.print(iterator.next()+" ");
}
System.out.println();
System.out.println("Now the size of list: " + list.size());
//Remove all
list.clear();
if (list.isEmpty()){
System.out.println("Linked list is empty");
}
else{
System.out.println( "Linked list size: " + size);
}
}
}
Output:
LinkedListExample
Linked List Example!
Linked list data: 11 22 33 44
Linked list size: 4
Adding data at 1st location: 55
Now the list contain: 55 11 22 33 44
Now the size of list: 5
Adding data at last location: 66
Now the list contain: 55 11 22 33 44 66
Now the size of list: 6
Adding data at 3rd location: 55
Now the list contain: 55 11 99 22 33 44 66
Now the size of list: 7
First data: 55
Last data: 66
Data at 4th position: 22
Data removed from 1st location: 55
Now the list contain: 11 99 22 33 44 66
Now the size of list: 6
Data removed from last location: 66
Now the list contain: 11 99 22 33 44
Now the size of list: 5
Data removed from 2nd location: 99
Now the list contain: 11 22 33 44
Now the size of list: 4
Linked list is empty