Is ArrayList ordered?

How to Maintain Insertion Order While Getting Unique Values from ArrayList in Java?

ArrayList is a part of collection framework and is present in java.util package. It provides us with dynamic arrays in Java. Though, it may be slower than standard arrays but can be helpful in programs where lots of manipulation in the array is needed. This class is found in java.util package.

If we want to maintain the insertion order of the elements, we are supposed to use LinkedHashSet. LinkedHashSet maintains the order in which the elements are inserted.

Example 1:

Java




// Java program to Maintain Insertion Order While
// Getting Unique Values from ArrayList
import java.util.*;
class GFG {
public static void main[String[] args]
{
// Creating an arrayList
ArrayList arrayList = new ArrayList[];
// adding elements to arrayList
arrayList.add[100];
arrayList.add[200];
arrayList.add[100];
arrayList.add[500];
arrayList.add[200];
arrayList.add[300];
arrayList.add[200];
arrayList.add[600];
// creating an LinkedHashSet and
// adding arrayList elements to linkedHashSet
LinkedHashSet set
= new LinkedHashSet[arrayList];
System.out.println[
"Unique values in inserted order"];
System.out.println[set];
}
}
Output Unique values in inserted order [100, 200, 500, 300, 600]

Example 2:

  • In this example, instead of using a wrapper class, we will use a user-defined class and will maintain insertion order while getting unique values from ArrayList.
  • Since we are using a user-defined class so we are supposed to override the hashCode method and equals method so that our LinkedHashSet will be able to identify similar elements otherwise our LinkedHashSet will consider every element as a unique element.
Java




// Java program to Maintain Insertion Order While
// Getting Unique Values from ArrayList
import java.util.*;
class friendsDetail {
// class field
private String name;
private String nickName;
// parameterised constructor
public friendsDetail[String name, String nickName]
{
this.name = name;
this.nickName = nickName;
}
// getter for name
public String getName[] { return name; }
// setter for name
public void setName[String name] { this.name = name; }
// getter for nickname
public String getnickName[] { return nickName; }
// setter for nickname
public void setNickName[int id]
{
this.nickName = nickName;
}
@Override public boolean equals[Object o]
{
if [this == o]
return true;
if [![o instanceof friendsDetail]]
return false;
friendsDetail that = [friendsDetail]o;
return Objects.equals[getName[], that.getName[]]
&& Objects.equals[nickName, that.nickName];
}
@Override public int hashCode[]
{
return Objects.hash[getName[], nickName];
}
// overriding toString method
public String toString[]
{
// return super.toString[];
return "[" + this.getName[] + ":"
+ this.getnickName[] + "]";
}
}
class GFG {
public static void main[String[] args]
{
ArrayList originalArrayList
= new ArrayList[];
System.out.println["Our ArrayList\n"];
originalArrayList.add[
new friendsDetail["Raushan", "Chamgader"]];
originalArrayList.add[
new friendsDetail["Yashdeep", "Dopa"]];
originalArrayList.add[
new friendsDetail["Shishya", "Gorilla"]];
originalArrayList.add[
new friendsDetail["Sonika", "Chipkali"]];
originalArrayList.add[
new friendsDetail["Himanshu", "Lalten"]];
originalArrayList.add[
new friendsDetail["Sarthak", "Nagin"]];
originalArrayList.add[
new friendsDetail["Tsering", "Battak"]];
originalArrayList.add[
new friendsDetail["Abhishek", "Liquid"]];
originalArrayList.add[
new friendsDetail["Shishya", "Gorilla"]];
originalArrayList.add[
new friendsDetail["Suraj", "Bhindi"]];
originalArrayList.add[
new friendsDetail["Sonika", "Chipkali"]];
originalArrayList.add[
new friendsDetail["Himanshu", "Lalten"]];
originalArrayList.add[
new friendsDetail["Sarthak", "Nagin"]];
// Displaying output using enhanced for loop
for [friendsDetail friend : originalArrayList] {
System.out.println[friend];
}
LinkedHashSet linkedHashSet
= new LinkedHashSet[originalArrayList];
System.out.println[
"\nUnique elements in inserted order\n"];
// Displaying output using enhanced for loop
for [friendsDetail friend : linkedHashSet] {
System.out.println[friend];
}
}
}
Output Our ArrayList [Raushan:Chamgader] [Yashdeep:Dopa] [Shishya:Gorilla] [Sonika:Chipkali] [Himanshu:Lalten] [Sarthak:Nagin] [Tsering:Battak] [Abhishek:Liquid] [Shishya:Gorilla] [Suraj:Bhindi] [Sonika:Chipkali] [Himanshu:Lalten] [Sarthak:Nagin] Unique elements in inserted order [Raushan:Chamgader] [Yashdeep:Dopa] [Shishya:Gorilla] [Sonika:Chipkali] [Himanshu:Lalten] [Sarthak:Nagin] [Tsering:Battak] [Abhishek:Liquid] [Suraj:Bhindi]




Article Tags :
Java
Java Programs
Technical Scripter
Java-ArrayList
Java-Collections
Technical Scripter 2020
Practice Tags :
Java
Java-Collections
Read Full Article

Video liên quan

Chủ Đề