$show=/label

Java PriorityQueue With Comparator

SHARE:

A quick guide to adding the comparator implementation to the PriorityQueue in java.

1. Overview

In this tutorial, We'll learn how to use the comparator with the PriorityQueue class in java to implement our own custom priority field.

This post covers in older java version and with java 8 later also.

PriorityQueue is a normal queue but it has the special ability to process them based on its priority field. That means each object inside the PriorityQueue is associated with the "priority" field.

This field decides which object should be popped out from the queue. Whichever is having the highest priority will be coming out first and the lowest priority one comes last from the PriorityQueue.

Let us write simple examples to understand PriorityQueue with a custom comparator.


Java PriorityQueue With Comparator



2. Java - PriorityQueue with Comparator


PriorityQueue class constructor comes with the comparator as an argument. We are now going to this one in the examples.

First, let us create a Customer class with the fields id, name and vip. Here, we add a few customer objects to the priority queue and then process the first vip customers and then the regular customers.

class Customer {

	private int id;
	private String name;
	private boolean vip;

	public Customer(int id, String name, boolean vip) {
		this.id = id;
		this.name = name;
		this.vip = vip;
	}

	public int getId() {
		return id;
	}

	public void setId(int id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public boolean isVip() {
		return vip;
	}

	public void setVip(boolean vip) {
		this.vip = vip;
	}

}

Now create the comparator implementation class with the vip logic. Here vip field is a boolean.

For boolean fields, we need to use Boolean.compareTo() method.

This VipComparator sorts based on the vip field and all vip customers are sent to the starting of the queue.
class VipComparator implements Comparator<Customer> {

	public int compare(Customer c1, Customer c2) {

		return Boolean.valueOf(c2.isVip()).compareTo(Boolean.valueOf(c1.isVip()));
	}
}

Next, create the main class with PriorityQueue and pass VipComparator object to the priority queue comparator.

And then add a few customers objects to it and iterated the priority queue through while loop.

package com.javaprogramto.java8.priorityqueue;

import java.util.Comparator;
import java.util.PriorityQueue;
import java.util.Queue;

public class PriorityQueueComparatorExample {

	public static void main(String[] args) {

		Queue<Customer> priorityVipQueue = new PriorityQueue<>(new VipComparator());

		priorityVipQueue.add(new Customer(1, "name 1", true));
		priorityVipQueue.add(new Customer(2, "Name 2", false));
		priorityVipQueue.add(new Customer(3, "Name 3", false));
		priorityVipQueue.add(new Customer(4, "Name 4", true));
		priorityVipQueue.add(new Customer(5, "Name 5", false));

		while (!priorityVipQueue.isEmpty()) {
			Customer c = priorityVipQueue.poll();
			System.out.println("Name - " + c.getName() + " - is Vip - " + c.isVip());
		}

	}
}

Output
Name - name 1 - is Vip - true
Name - Name 4 - is Vip - true
Name - Name 2 - is Vip - false
Name - Name 3 - is Vip - false
Name - Name 5 - is Vip - false

From the output, we can see that first all priority customers are processed first and at the last, all non-priority customers have been taken care of.


3. Java 8 - PriorityQueue with Comparator


Adding the custom comparator to PriorityQueue can be done in java 8 2 ways.

3.1 Using Lamba Expression


The same comparator can be created using Java 8 api. We do not need to create a new class for VipComparator now because we can use the lambda expressions from java 8.
public class PriorityQueueComparatorExample2 {

	public static void main(String[] args) {

		Queue<Customer> priorityVipQueue = new PriorityQueue<>(
				(c1, c2) -> Boolean.valueOf(c2.isVip()).compareTo(Boolean.valueOf(c1.isVip())));

		priorityVipQueue.add(new Customer(1, "name 1", true));
		priorityVipQueue.add(new Customer(2, "Name 2", false));
		priorityVipQueue.add(new Customer(3, "Name 3", false));
		priorityVipQueue.add(new Customer(4, "Name 4", true));
		priorityVipQueue.add(new Customer(5, "Name 5", false));

		while (!priorityVipQueue.isEmpty()) {
			Customer c = priorityVipQueue.poll();
			System.out.println("Name - " + c.getName() + " - is Vip - " + c.isVip());
		}

	}

}

We can see clearly, comparator code is reduced to a single line with the help of lambda's.

Let us execute the code and see the output is expected or not.

Output
Name - name 1 - is Vip - true
Name - Name 4 - is Vip - true
Name - Name 2 - is Vip - false
Name - Name 3 - is Vip - false
Name - Name 5 - is Vip - false


3.2 Using Method Reference


Method references can be used to create the comparator using Comparator.comparing() method.
Queue<Customer> priorityVipQueue = new PriorityQueue<>(Comparator.comparing(Customer::isVip).reversed());

This code also produces the same output but the comparator has to reverse using Comparator.reversed() method.




4. Conclusion


In this article, we've seen how to implement a comparator for PriorityQueue in java and new java 8 versions.



COMMENTS

BLOGGER

About Us

Author: Venkatesh - I love to learn and share the technical stuff.
Name

accumulo,1,ActiveMQ,2,Adsense,1,API,37,ArrayList,18,Arrays,24,Bean Creation,3,Bean Scopes,1,BiConsumer,1,Blogger Tips,1,Books,1,C Programming,1,Collection,8,Collections,37,Collector,1,Command Line,1,Comparator,1,Compile Errors,1,Configurations,7,Constants,1,Control Statements,8,Conversions,6,Core Java,149,Corona India,1,Create,2,CSS,1,Date,3,Date Time API,38,Dictionary,1,Difference,2,Download,1,Eclipse,3,Efficiently,1,Error,1,Errors,1,Exceptions,8,Fast,1,Files,17,Float,1,Font,1,Form,1,Freshers,1,Function,3,Functional Interface,2,Garbage Collector,1,Generics,4,Git,9,Grant,1,Grep,1,HashMap,2,HomeBrew,2,HTML,2,HttpClient,2,Immutable,1,Installation,1,Interview Questions,6,Iterate,2,Jackson API,3,Java,32,Java 10,1,Java 11,6,Java 12,5,Java 13,2,Java 14,2,Java 8,128,Java 8 Difference,2,Java 8 Stream Conversions,4,java 8 Stream Examples,12,Java 9,1,Java Conversions,14,Java Design Patterns,1,Java Files,1,Java Program,3,Java Programs,114,Java Spark,1,java.lang,4,java.util. function,1,JavaScript,1,jQuery,1,Kotlin,11,Kotlin Conversions,6,Kotlin Programs,10,Lambda,2,lang,29,Leap Year,1,live updates,1,LocalDate,1,Logging,1,Mac OS,3,Math,1,Matrix,6,Maven,1,Method References,1,Mockito,1,MongoDB,3,New Features,1,Operations,1,Optional,6,Oracle,5,Oracle 18C,1,Partition,1,Patterns,1,Programs,1,Property,1,Python,2,Quarkus,1,Read,1,Real Time,1,Recursion,2,Remove,2,Rest API,1,Schedules,1,Serialization,1,Servlet,2,Sort,1,Sorting Techniques,8,Spring,2,Spring Boot,23,Spring Email,1,Spring MVC,1,Streams,31,String,61,String Programs,28,String Revese,1,StringBuilder,1,Swing,1,System,1,Tags,1,Threads,11,Tomcat,1,Tomcat 8,1,Troubleshoot,26,Unix,3,Updates,3,util,5,While Loop,1,
ltr
item
JavaProgramTo.com: Java PriorityQueue With Comparator
Java PriorityQueue With Comparator
A quick guide to adding the comparator implementation to the PriorityQueue in java.
https://blogger.googleusercontent.com/img/a/AVvXsEinbodbsMl9IeU_d_w7PWBucJkm8_3houE5I0EDdLDSlSpKIKtTcTiGJpaS3u2SIQXzf7GbpyQoqjfgBkSubIjji-WfCtfpdTYS5Yy0h08JScdeSQLEFx7UjbX_HdztGg93yiVb6e3wqh1_GKn-olvxiuRtLVe8Qa1oBhOSHYG2iRi9WEs1-v_NNi_k=w400-h255
https://blogger.googleusercontent.com/img/a/AVvXsEinbodbsMl9IeU_d_w7PWBucJkm8_3houE5I0EDdLDSlSpKIKtTcTiGJpaS3u2SIQXzf7GbpyQoqjfgBkSubIjji-WfCtfpdTYS5Yy0h08JScdeSQLEFx7UjbX_HdztGg93yiVb6e3wqh1_GKn-olvxiuRtLVe8Qa1oBhOSHYG2iRi9WEs1-v_NNi_k=s72-w400-c-h255
JavaProgramTo.com
https://www.javaprogramto.com/2021/12/java-priorityqueue-comparator.html
https://www.javaprogramto.com/
https://www.javaprogramto.com/
https://www.javaprogramto.com/2021/12/java-priorityqueue-comparator.html
true
3124782013468838591
UTF-8
Loaded All Posts Not found any posts VIEW ALL Readmore Reply Cancel reply Delete By Home PAGES POSTS View All RECOMMENDED FOR YOU LABEL ARCHIVE SEARCH ALL POSTS Not found any post match with your request Back Home Sunday Monday Tuesday Wednesday Thursday Friday Saturday Sun Mon Tue Wed Thu Fri Sat January February March April May June July August September October November December Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec just now 1 minute ago $$1$$ minutes ago 1 hour ago $$1$$ hours ago Yesterday $$1$$ days ago $$1$$ weeks ago more than 5 weeks ago Followers Follow THIS PREMIUM CONTENT IS LOCKED STEP 1: Share to a social network STEP 2: Click the link on your social network Copy All Code Select All Code All codes were copied to your clipboard Can not copy the codes / texts, please press [CTRL]+[C] (or CMD+C with Mac) to copy Table of Content