Skip to main content

Java Comparator Hackerrank Solution with Explanation | Programming Blog

Comparing Objects with Comparator in Java | Compare and Sort two Objects in Java

Java Comparator Hackerrank Solution

Comparators are used to compare two objects. In this challenge, you'll create a comparator and use it to sort an array.

The Player class is provided for you in your editor. It has 2 fields : a name string and score integer.

Given an array of n Player objects, write a comparator that sorts them in order of decreasing score; if 2 or more players have the same score, sort those players alphabetically by name. To do this, you must create a Checker class that implements the Comparator interface, then write an int compare(Player a, Player b) method implementing the Comparator.compare(T o1, T o2) method.

Input Format

Input from stdin is handled by the locked stub code in the Solution class.
The first line contains an integer, n, denoting the number of players.
Each of the n subsequent lines contains a player's name and score, respectively.

Read full description on Hackerrank Website :-

So let's see solution of above problem.

If you want to learn about Comparator interface in java. Check out below link :-

Solution 1 :-

import java.util.*;

// Write your Checker class here

class Checker implements Comparator<Player> {
    @Override
    public int compare(Player o1, Player o2) {
       if (o1.score > o2.score) {
           return -1;
       } if (o1.score < o2.score) {
           return 1;
       } if (o1.score == o2.score) {
           return o1.name.compareTo(o2.name);
       }
    return 0;
    }
}



class Player{
    String name;
    int score;
    
    Player(String name, int score){
        this.name = name;
        this.score = score;
    }
}

class Solution {

    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int n = scan.nextInt();

        Player[] player = new Player[n];
        Checker checker = new Checker();
        
        for(int i = 0; i < n; i++){
            player[i] = new Player(scan.next(), scan.nextInt());
        }
        scan.close();
     
        Arrays.sort(player, checker);
        for(int i = 0; i < player.length; i++){
            System.out.printf("%s %s\n", player[i].name, player[i].score);
        }
    }
}

Input and Output :-

Input
5
amy 100
david 100
heraldo 50
aakansha 75
aleksa 150

Output
aleksa 150
amy 100
david 100
aakansha 75
heraldo 50

Explanation :-

  • Created one Checker class as given instruction. And implements Comparator in Checker class.
  • If you implements Comparable interface then you must to Override its compare method. Same we done in above example.
  • compare functions returns negative integer, zero, or a positive integer, -1, 0, 1.(In Increment order, In decrement order below things are done in Reverse)
    • Return Negative integer (-1) :- When First argument is Less than Second argument.
    • Return Positive integer (1) :- When First argument is Greater than Second argument.
    • Return 0 :- When First argument is Equals to Second argument. 
  •  So, first we check score and if score are same for two objects then we check compare using name, and returns based on that.

We can also minimize above solution.

Solution 2 :-

class Checker implements Comparator<Player> {
    @Override
    public int compare(Player p1, Player p2) {
        if (p1.score == p2.score) {
            return p1.name.compareTo(p2.name);
        } else {
            return p2.score - p1.score;
        }
    }
}

Solution 3 :-

class Checker implements Comparator<Player> {
    @Override
    public int compare(Player o1, Player o2) {
     return (o2.score == o1.score)
        ? o1.name.compareTo(o2.name)
        : o2.score - o1.score;
    }
}

Explanation :-

Here we doing same thing as above solution. 

  • If both objects mark property are same then compare using name property, otherwise compare using score.
 
Happy Coding..
 
Comparing Objects with Comparable interface in Java :-
Sort Object with NULL values using Comparator interface in Java
 

Comments

Popular posts from this blog

Queen's Attack II HackerRank Solution in Java with Explanation

Queen's Attack II Problem's Solution in Java (Chessboard Problem)   Problem Description : You will be given a square chess board with one queen and a number of obstacles placed on it. Determine how many squares the queen can attack.  A queen is standing on an n * n chessboard. The chess board's rows are numbered from 1 to n, going from bottom to top. Its columns are numbered from 1 to n, going from left to right. Each square is referenced by a tuple, (r, c), describing the row r and column c, where the square is located. The queen is standing at position (r_q, c_q). In a single move, queen can attack any square in any of the eight directions The queen can move: Horizontally (left, right) Vertically (up, down) Diagonally (four directions: up-left, up-right, down-left, down-right) The queen can move any number of squares in any of these directions, but it cannot move through obstacles. Input Format : n : The size of the chessboard ( n x n ). k : The number of obstacles...

Sales by Match HackerRank Solution | Java Solution

HackerRank Sales by Match problem solution in Java   Problem Description : Alex works at a clothing store. There is a large pile of socks that must be paired by color for sale. Given an array of integers representing the color of each sock, determine how many pairs of socks with matching colors there are. For example, there are n=7 socks with colors socks = [1,2,1,2,1,3,2]. There is one pair of color 1 and one of color 2 . There are three odd socks left, one of each color. The number of pairs is 2 .   Example 1 : Input : n = 6 arr = [1, 2, 3, 4, 5, 6] Output : 0 Explanation : We have 6 socks with all different colors, So print 0. Example 2 : Input : n = 10 arr = [1, 2, 3, 4, 1, 4, 2, 7, 9, 9] Output : 4 Explanation : We have 10 socks. There is pair of color 1, 2, 4 and 9, So print 4. This problem easily solved by HashMap . Store all pair of socks one by one in Map and check if any pair is present in Map or not. If pair is present then increment ans variable by 1 ...