The Vector class implements a growable array of objects. Vectors basically fall in legacy classes but now it is fully compatible with collections. It is found in java.util package and implements the List interface, so we can use all the methods of the List interface.
There are two types of Sorting technique:
- First is internal sorting i.e that uses predefined sorting method ascending order Arrays.sort() for Primitive class arrays and wrapper class arrays and Collections.sort() for collections both methods sort the elements in ascending order.
- The second technique is passing the comparator or implement the comparator interface in the class as the second argument in both methods and change the sorting the order according to the requirements. Comparator only works for wrapper class type arrays and for collections like vector, ArrayList, etc.
Input:
vector [4,3,2,6,7]
Output:
vector [2,3,4,6,7]
Approaches to sort vector in descending order using Comparator:
- Implement the comparator interface in the class and change the natural ordering of the elements
- Directly call the new comparator in the second argument of the Collections.sort() method and change the ordering of the element
Example 1: Overriding the compare method inside the class that implements the Comparator class and then creating and passing the object of that class as a second parameter while calling the Collections.sort() method.
// Java program to Sort Java Vector in // descending order using comparator import java.io.*;
import java.util.*;
// Implement comparator of the Integer class class GFG implements Comparator<Integer>
{ // Function to print the elements of the vector
static void print(Vector<Integer> Numbers)
{
for (Integer number : Numbers)
{
// Printing the elements
System.out.print(number + " " );
}
}
public static void main(String[] args)
{
// Implementing the vector class
Vector<Integer> elements = new Vector<>();
// Adding elements in the vector class
elements.add( 4 );
elements.add( 3 );
elements.add( 2 );
elements.add( 6 );
elements.add( 7 );
// Before sorting the elements
System.out.print( "Before sorting elements " );
print(elements);
System.out.println();
// Sorting the vector elements in descending
// order
Collections.sort(elements, new GFG());
System.out.print( "After sorting elements " );
// Printing the elements
print(elements);
}
// Implementing compare function
@Override public int compare(Integer o1, Integer o2)
{
// Changing the order of the elements
return o2 - o1;
}
} |
Before sorting elements 4 3 2 6 7 After sorting elements 7 6 4 3 2
Example 2: Overriding the compare function at the time of calling the Collections.sort() method there itself.
// Java program to Sort Java Vector in // descending order using comparator import java.io.*;
import java.util.*;
class GFG {
// Function to print the elements of the vector
static void print(Vector<Integer> Numbers)
{
for (Integer number : Numbers) {
// Printing the elements
System.out.print(number + " " );
}
}
public static void main(String[] args)
{
// Implementing the vector class
Vector<Integer> elements = new Vector<>();
// Adding elements in the vector class
elements.add( 4 );
elements.add( 3 );
elements.add( 2 );
elements.add( 6 );
elements.add( 7 );
// Before sorting the elements
System.out.print( "Before sorting elements " );
print(elements);
System.out.println();
// Sorting the vector elements in descending
// order
Collections.sort(
elements, new Comparator<Integer>() {
@Override
public int compare(Integer o1, Integer o2)
{
// Changing the order of the elements
return o2 - o1;
}
});
System.out.print( "After sorting elements " );
// Printing the elements
print(elements);
}
} |
Before sorting elements 4 3 2 6 7 After sorting elements 7 6 4 3 2