-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathJava Priority Queue.java
More file actions
72 lines (66 loc) · 1.89 KB
/
Java Priority Queue.java
File metadata and controls
72 lines (66 loc) · 1.89 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
import java.io.*;
import java.util.*;
import java.text.*;
import java.math.*;
import java.util.regex.*;
// Java 15
class Student{
private int token;
private String fname;
private double cgpa;
public Student(int id, String fname, double cgpa) {
super();
this.token = id;
this.fname = fname;
this.cgpa = cgpa;
}
public int getToken() {
return token;
}
public String getFname() {
return fname;
}
public double getCgpa() {
return cgpa;
}
}
public class Solution {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int totalEvents = Integer.parseInt(in.nextLine());
PriorityQueue<Student> list =
new PriorityQueue<>(new Comparator<Student>() {
@Override
public int compare(Student o1, Student o2) {
if(o1.getCgpa() != o2.getCgpa())
return o1.getCgpa() < o2.getCgpa() ? 1 : -1;
else{
if(!o1.getFname().equals(o2.getFname()))
return o1.getFname().compareTo(o2.getFname());
else
return o1.getToken() < o2.getToken() ? 1 : -1;
}
}
});
while(totalEvents>0){
String event = in.next();
if(event.equals("ENTER")){
String name = in.next();
double gpa = in.nextDouble();
int id = in.nextInt();
list.add(new Student(id, name, gpa));
}else if(list.size() > 0 && event.equals("SERVED")){
list.remove();
}
totalEvents--;
}
if(list.size() == 0) {
System.out.println("EMPTY");
return;
}
while(list.size() > 0){
System.out.println(list.poll().getFname());
}
}
}
// Keep Going.