Register for our webinar

How to Nail your next Technical Interview

1 hour
Loading...
1
Enter details
2
Select webinar slot
*Invalid Name
*Invalid Name
By sharing your contact details, you agree to our privacy policy.
Step 1
Step 2
Congratulations!
You have registered for our webinar
check-mark
Oops! Something went wrong while submitting the form.
1
Enter details
2
Select webinar slot
*All webinar slots are in the Asia/Kolkata timezone
Step 1
Step 2
check-mark
Confirmed
You are scheduled with Interview Kickstart.
Redirecting...
Oops! Something went wrong while submitting the form.
close-icon
Iks white logo

You may be missing out on a 66.5% salary hike*

Nick Camilleri

Head of Career Skills Development & Coaching
*Based on past data of successful IK students
Iks white logo
Help us know you better!

How many years of coding experience do you have?

Thank you! Your submission has been received!
Oops! Something went wrong while submitting the form.
Iks white logo

FREE course on 'Sorting Algorithms' by Omkar Deshpande (Stanford PhD, Head of Curriculum, IK)

Thank you! Please check your inbox for the course details.
Oops! Something went wrong while submitting the form.
Our June 2021 cohorts are filling up quickly. Join our free webinar to Uplevel your career
close
closeAbout usWhy usInstructorsReviewsCostFAQContactBlogRegister for Webinar

Collections Sort in Java

Last updated by Vartika Rai on Sep 25, 2024 at 11:00 PM | Reading time: 9 minutes

The fast well prepared banner

Attend our Free Webinar on How to Nail Your Next Technical Interview

WEBINAR +LIVE Q&A

How To Nail Your Next Tech Interview

Collections Sort in Java
Hosted By
Ryan Valles
Founder, Interview Kickstart
strategy
Our tried & tested strategy for cracking interviews
prepare list
How FAANG hiring process works
hiring process
The 4 areas you must prepare for
hiring managers
How you can accelerate your learnings

Collections sort in Java provides in-built methods to sort data faster and in an easier manner. Many software engineering interviews require sorting of a list or an array; implementing a sorting algorithm from scratch in an interview can be cumbersome. For some problems, the sorting part of the task can be simplified using the abilities of Java Collections. In this article, we will cover Collections sort in Java in detail:

  • What is Java Collections sort?
  • How Does Collections Sort Work in Java?
  • Arrays.sort() vs. Collections.sort()
  • Problems on Collections Sort in Java 
  • FAQs on Collections Sort in Java

What Is Java Collections Sort?

Collections sort is a method of Java Collections class used to sort a list, which implements the List interface. All the elements in the list must be mutually comparable. If a list consists of string elements, then it will be sorted in alphabetical order. If it consists of a date element, it will be sorted into chronological order. 

How does it happen? String and date both implement the Comparable interface in Java. Comparable implementations provide a natural ordering for a class, which allows the object of that class to be sorted properly.

ClassCastException: If the list contains elements that are not mutually comparable using the specified comparator, it will throw ClassCastException. 

The sort is guaranteed to be stable, i.e., the order of equal elements after performing sort will remain unchanged. By default, this method sorts the list in ascending order of elements. Collections.sort is used to sort all data structures such as linkedList, ArrayList, and queue. 

Implementation of the Collections Sort Method in Java

The Collections.sort has two overloaded methods :

  1. public static void sort(List list): Sort the list into ascending order, the natural ordering of its element. 
  2. public static void sort(List list, Comparator c): Sort the list according to the specified comparator. 

Let’s take an example to sort the list of elements in ascending order. We have a list of student names, and we’ll sort them in ascending order. 

public static void sort(List studentName) 

import java.util.*;

class Main {

   public static void main(String[] args) {

       List<String> studentName = Arrays.asList("Tom","John","Harry","Philip","Max");

       Collections.sort(studentName);

       for(String name : studentName) {

           System.out.println(name);

       }

   }

}

Output: 

public static void sort(List list, Comparator c)

By default, Collections.sort will sort the names in alphabetical order. We can also sort the student names in descending order using Collections.reverseOrder(). 

import java.util.*;

class Main {

   public static void main(String[] args) {

       List<String> studentName = Arrays.asList("Tom","John","Harry","Philip","Max");

       Collections.sort(studentName, Collections.reverseOrder());

       for(String name : studentName) {

           System.out.println(name);

       }

   }

}

Output:

Sorting in descending order can be done using a comparator too. Let’s have a look at the code below. 

import java.util.*;

class Main {

   public static void main(String[] args) {

       List<String> studentName = Arrays.asList("Tom","John","Harry","Philip","Max");

       Collections.sort(studentName, new Comparator<String>(){

            public int compare(String a, String b) {

                return b.compareTo(a);

            }

        });

       for(String name : studentName) {

           System.out.println(name);

       }

   }

}


This can also be done using lambda expressions:

import java.util.*;

class Main {

   public static void main(String[] args) {

       List<String> studentName = Arrays.asList("Tom","John","Harry","Philip","Max");

       Collections.sort(studentName, (a, b)-> b.compareTo(a));

        studentName.forEach((name)->System.out.println(name));

   }

}

Let’s take an example to understand comparator-based sorting. We have a list of student details, and we want to sort them based on their total marks. 

Student details: Name, mathScore, physicsScore, chemistryScore

We have all the scores obtained by the students in each subject. We want to sort the list of the students based on their total marks (mathScore + physicsScore + chemistryScore). Let’s assume that two students' total marks can’t be equal in this case. 

import java.util.*;

class Student {

    String name;

    int mathMarks;

    int physicsMarks;

    int chemistryMarks;

    Student(String name, int mathMarks, int physicsMarks, int chemistryMarks) {

        this.name = name;

        this.mathMarks = mathMarks;

        this.physicsMarks = physicsMarks;

        this.chemistryMarks = chemistryMarks;

    }

    @Override

    public String toString(){

        return this.name + " " + this.mathMarks + " " + this.physicsMarks + " " + this.chemistryMarks;

    }

    public int totalMarks() {

        return this.mathMarks + this.physicsMarks + this.chemistryMarks;

    }

    public static void main(String [] args) {

        List<Student> listOfStudents = new ArrayList<>();

        listOfStudents.add(new Student("John", 70, 50, 80));

        listOfStudents.add(new Student("Tom", 40, 50, 60));

        listOfStudents.add(new Student("Harry", 90, 50, 40));

        listOfStudents.add(new Student("Max", 80, 90, 40));

        listOfStudents.add(new Student("Philip", 60, 70, 90));

        // sort using lambda supported by  java 8 and above

        Collections.sort(listOfStudents, new Comparator<Student>() {

            public int compare(Student student1, Student student2) {

                return student1.totalMarks() - student2.totalMarks();

            }

        });

        for(Student student: listOfStudents) {

            System.out.println(student.toString());

        }

    }

}

Output

We can also use lambda expressions here. Let’s have a look at the code below. 

import java.util.*;

class Student {

    String name;

    int mathMarks;

    int physicsMarks;

    int chemistryMarks;

    Student(String name, int mathMarks, int physicsMarks, int chemistryMarks) {

        this.name = name;

        this.mathMarks = mathMarks;

        this.physicsMarks = physicsMarks;

        this.chemistryMarks = chemistryMarks;

    }

    @Override

    public String toString(){

        return this.name + " " + this.mathMarks + " " + this.physicsMarks + " " + this.chemistryMarks;

    }

    public int totalMarks() {

        return this.mathMarks + this.physicsMarks + this.chemistryMarks;

    }

    public static void main(String [] args) {

        List<Student> listOfStudents = new ArrayList<>();

        listOfStudents.add(new Student("John", 70, 50, 80));

        listOfStudents.add(new Student("Tom", 40, 50, 60));

        listOfStudents.add(new Student("Harry", 90, 50, 40));

        listOfStudents.add(new Student("Max", 80, 90, 40));

        listOfStudents.add(new Student("Philip", 60, 70, 90));

        // sort using lambda supported by  java 8 and above

        Collections.sort(listOfStudents, (student1, student2) -> student1.totalMarks() - student2.totalMarks());

        listOfStudents.forEach((student)-> System.out.println(student.toString()));

    }

}

How Does Collections Sort Work in Java?

The sort method transfers control to the compare method, and compare method returns values based on the arguments passed: 

  • If both the objects are equal, returns 0 
  • If the first object is greater than the second, returns a value > 0 
  • If the second object is greater than the first, returns a value < 0

Based on the values returned, the function decides whether to swap the values.

Problems on Collections Sort in Java 

  1. Given: n activities with their start and end times.
    Task: What are the maximum number of activities that can be performed by a single person, assuming that one person can only work one activity at a time. 
  2. Given: An array of jobs, where every job has a deadline and an associated profit if the job is completed within the deadline. Each job takes a single unit of time, so the minimum possible deadline for any job is 1.
    Task: Maximize the total profit if only one job can be scheduled at a time.
For more tech interview questions and problems, check out the following pages: Interview Questions and Problems

FAQs on Collections Sort in Java

Question 1: What is the difference between Arrays.sort() vs. Collections.sort()?

Answer: Collections.sort operates on a list, while Arrays.sort operates on an array. Arrays.sort() and Collections.sort() use two different algorithms. Internally, Collections.sort converts the input list into an array and calls Arrays.sort to sort the resulting array.

Question 2: Can we use Collections.sort to sort a 2-dimensional array?

Answer: Yes. We can use Collections to sort a 2-dimensional array. Following is an example, where we sort the given 2D array based on the first element:

import java.util.*;

class Main {

    public static void main(String[] args) {

        int[][] array = {

            {3, 10},{18, 1}

        };

        Arrays.sort(array, new Comparator<int[]>(){

            @Override

            public int compare(int[] o1, int[] o2) {

                return Integer.compare(o1[0],o2[0]);

            }

        });

        for(int i = 0; i< array.length; i++) {

            for(int j = 0; j < array[i].length; j++) {

                System.out.print(array[i][j]+" ");

            }System.out.println();

        }

    }

}

In the example, we have sorted each array[i] based on the first values present in them as there is no default way to sort an array of arrays.

Question 3: Can we sort a sublist using Collections.sort()?

Answer: No. Collections.sort() doesn’t provide any built-in method to sort the sublist, but we can sort a subarray using Arrays.sort(). We can pass the fromIndex and toIndex along with the array. Let’s see an example: 

import java.util.Arrays;

import java.util.Comparator;

class Main {

   public static void main(String[] args) {              

       Integer array[] = { 1 , 5 , 3, 4 , 2 , 7 , 6 };

       Arrays.sort(array, 1 , 5 , new Comparator<Integer>(){

           @Override

           public int compare(Integer o1, Integer o2) {

               return Integer.compare(o1,o2);

           }

       });

      

       for(int i = 0; i< array.length; i++) {

           System.out.print(array[i]+" ");

       }

   }

}

Output: 1 2 3 4 5 7 6

As evident from the sample output, we sorted the range [fromIndex, endIndex). Here, fromIndex is included, and endIndex is excluded.

Also, since the array is 0-indexed, we sorted the range [1, 5), where index 1 is included, and index 5 is excluded.

Ace Your Next Tech Interview With Interview Kickstart!

If you’re looking for guidance and help to nail your next technical interview, sign up for our free webinar. As pioneers in the field of technical interview prep, we have trained thousands of software engineers to crack the toughest coding interviews and land their dream jobs at Google, Facebook, Apple, Netflix, Amazon, and other Tier-1 tech companies.

Join our webinar to learn more!

Recommended Reading

Check out our learn page for more articles on Java:

----------

Article contributed Problem Setters Official

Last updated on: 
October 10, 2024
Author

Vartika Rai

Product Manager at Interview Kickstart | Ex-Microsoft | IIIT Hyderabad | ML/Data Science Enthusiast. Working with industry experts to help working professionals successfully prepare and ace interviews at FAANG+ and top tech companies

Attend our Free Webinar on How to Nail Your Next Technical Interview

Register for our webinar

How to Nail your next Technical Interview

1
Enter details
2
Select webinar slot
First Name Required*
Last Name Required*
By sharing your contact details, you agree to our privacy policy.
Step 1
Step 2
Congratulations!
You have registered for our webinar
check-mark
Oops! Something went wrong while submitting the form.
1
Enter details
2
Select webinar slot
Step 1
Step 2
check-mark
Confirmed
You are scheduled with Interview Kickstart.
Redirecting...
Oops! Something went wrong while submitting the form.

Collections Sort in Java

Worried About Failing Tech Interviews?

Attend our webinar on
"How to nail your next tech interview" and learn

Ryan-image
Hosted By
Ryan Valles
Founder, Interview Kickstart
blue tick
Our tried & tested strategy for cracking interviews
blue tick
How FAANG hiring process works
blue tick
The 4 areas you must prepare for
blue tick
How you can accelerate your learnings
Register for Webinar
entroll-image