I C++ har vi std::par i bruksbiblioteket som er til stor nytte hvis vi ønsker å holde et par verdier sammen. Vi var på utkikk etter en tilsvarende klasse for par i Java, men parklassen ble ikke til før Java 7. JavaFX 2.2 har javafx.util.Pair klasse som kan brukes til å lagre et par. Vi må lagre verdiene i Pair ved å bruke den parameteriserte konstruktøren levert av javafx.util.Pair klasse.
Merk: Merk at paret brukes i HashMap/TreeMap . Her refererer det ganske enkelt til et par verdier som er lagret sammen.
Metoder levert av javafx.util.Pair-klassen
Syntaks: Parklassen i Java-metoden
Pair var_name = new Pair(key, value);>
- Par (K-tast, V-verdi): Oppretter et nytt par.
- boolsk lik(): Den brukes til å sammenligne to par objekter. Den gjør en dyp sammenligning, dvs. den sammenligner på grunnlag av verdiene () som er lagret i parobjektene.
Eksempel:
java
tilfeldig ingen generator i java
Pair p1 =>new> Pair(>3>,>4>);> Pair p2 =>new> Pair(>3>,>4>);> Pair p3 =>new> Pair(>4>,>4>);> System.out.println(p1.equals(p2) + + p2.equals(p3));> |
>
1 milliard til million
>
Produksjon:
true false>
- String toString(): Denne metoden vil returnere strengrepresentasjonen av paret.
- K getKey(): Den returnerer nøkkelen for paret.
- V getValue(): Det returnerer en verdi for paret.
- int hashCode(): Generer en hash-kode for paret.
Tilgang til verdier: Ved hjelp av getKey() og getValue() metoder vi kan få tilgang til et par-objekts verdier.
1. getKey(): får den første verdien.
2. getValue(): får den andre verdien
Merk: Her refererer til et par verdier som er lagret sammen. Det er ikke som par som brukes i Map.
Gjennomføring:
Java
// Java program to implement in-built pair classes> import> javafx.util.Pair;> class> GFG {> >// Main driver method> >public> static> void> main(String[] args)> >{> >Pair p> >=>new> Pair(>10>,>'Hello Geeks!'>);> >// printing the values of key and value pair> >// separately> >System.out.println(>'The First value is :'> >+ p.getKey());> >System.out.println(>'The Second value is :'> >+ p.getValue());> >}> }> |
>
streng int
>
La oss ta en titt på følgende problem.
Problemstilling : Vi får navnene på n elever med deres tilsvarende poengsum oppnådd i en quiz. Vi må finne eleven med maksimal poengsum i klassen.
Merk: Du må ha Java 8 installert på maskinen din for å kjøre programmet nedenfor.
Java
støp streng til int
// Java program to find a Pair which has maximum score> // Importing required classes> import> java.util.ArrayList;> import> javafx.util.Pair;> // class> class> Test {> >// This method returns a Pair which hasmaximum score> >public> static> Pair> >getMaximum(ArrayList l)> >{> >// Assign minimum value initially> >int> max = Integer.MIN_VALUE;> >// Pair to store the maximum marks of a> >// student with its name> >Pair ans> >=>new> Pair(>''>,>0>);> >// Using for each loop to iterate array of> >// Pair Objects> >for> (Pair temp : l) {> >// Get the score of Student> >int> val = temp.getValue();> >// Check if it is greater than the previous> >// maximum marks> >if> (val>maks) {> >max = val;>// update maximum> >ans = temp;>// update the Pair> >}> >}> >return> ans;> >}> >// Driver method to test above method> >public> static> void> main(String[] args)> >{> >int> n =>5>;>// Number of Students> >// Create an Array List> >ArrayList l> >=>new> ArrayList();> >/* Create pair of name of student with their> >corresponding score and insert into the> >Arraylist */> >l.add(>new> Pair(>'Student A'>,>90>));> >l.add(>new> Pair(>'Student B'>,>54>));> >l.add(>new> Pair(>'Student C'>,>99>));> >l.add(>new> Pair(>'Student D'>,>88>));> >l.add(>new> Pair(>'Student E'>,>89>));> >// get the Pair which has maximum value> >Pair ans = getMaximum(l);> >System.out.println(ans.getKey() +>' is top scorer '> >+>'with score of '> >+ ans.getValue());> >}> }> |
>
>
Produksjon:
Student C is top scorer with score of 99>
Merk: Programmet ovenfor kjører kanskje ikke i en online IDE, vennligst bruk en frakoblet kompilator.