logo

Vergelijkbare interface in Java met voorbeelden

De Comparable-interface wordt gebruikt om een ​​object van dezelfde klasse te vergelijken met een exemplaar van die klasse. Het biedt ordening van gegevens voor objecten van de door de gebruiker gedefinieerde klasse. De klas moet de java.lang.Vergelijkbaar interface om zijn instantie te vergelijken, biedt het de methode CompareTo die een parameter van het object van die klasse gebruikt. In dit artikel zullen we zien hoe we een array van paren van verschillende gegevenstypen kunnen sorteren op basis van de verschillende vergelijkingsparameters.

Vergelijkbare interface gebruiken

  • Bij deze methode gaan we de vergelijkbare interface van implementeren java.lang Pakket in de Pair-klasse.
  • De Vergelijkbare interface bevat de methode vergelijk met om de volgorde van de elementen te bepalen.
  • Overschrijf de vergelijk met methode in de klasse Pair.
  • Maak een array van paren en vul de array.
  • Gebruik de Arrays.sorteren () functie om de array te sorteren.

voorbeeld 1

Gegeven een array van paren bestaande uit twee velden van het type string en geheel getal. je moet de array in oplopende lexicografische volgorde sorteren en als twee strings hetzelfde zijn, sorteer je deze op basis van hun gehele waarde.



Voorbeeld-I/O:

Input: { {'abc', 3}, {'a', 4}, {'bc', 5}, {'a', 2} } Output: { {'a', 2}, {'a', 4}, {'abc', 3}, {'bc', 5} } Input: { {'efg', 1}, {'gfg', 1}, {'cba', 1}, {'zaa', 1} } Output: { {'cba', 1}, {'efg', 1}, {'gfg', 1}, {'zaa', 1} }>

Java




numpige standaarddeviatie

willekeurig getal in Java





import> java.io.*;> import> java.util.*;> class> Pair>implements> Comparable {> >String x;> >int> y;> >public> Pair(String x,>int> y)> >{> >this>.x = x;> >this>.y = y;> >}> >public> String toString()> >{> >return> '('> + x +>','> + y +>')'>;> >}> >@Override> public> int> compareTo(Pair a)> >{> >// if the string are not equal> >if> (>this>.x.compareTo(a.x) !=>0>) {> >return> this>.x.compareTo(a.x);> >}> >else> {> >// we compare int values> >// if the strings are equal> >return> this>.y - a.y;> >}> >}> }> public> class> GFG {> >public> static> void> main(String[] args)> >{> >int> n =>4>;> >Pair arr[] =>new> Pair[n];> >arr[>0>] =>new> Pair(>'abc'>,>3>);> >arr[>1>] =>new> Pair(>'a'>,>4>);> >arr[>2>] =>new> Pair(>'bc'>,>5>);> >arr[>3>] =>new> Pair(>'a'>,>2>);> >// Sorting the array> >Arrays.sort(arr);> >// printing the> >// Pair array> >print(arr);> >}> >public> static> void> print(Pair[] arr)> >{> >for> (>int> i =>0>; i System.out.println(arr[i]); } } }>

>

Madhubala
>

Uitgang:

 Before Sorting: (abc, 3); (a, 4); (bc, 5); (a, 2); After Sorting: (a,2) (a,4) (abc,3) (bc,5)>

Opmerking: als twee strings hetzelfde zijn, wordt de vergelijking uitgevoerd op basis van de waarde.

Voorbeeld 2

Gegeven een array van paren bestaande uit twee strings met voor- en achternaam. je moet de array sorteren in oplopende lexicografische volgorde van de voornaam en als twee strings hetzelfde zijn, sorteer je deze op basis van hun achternaam.

sorteer een arraylist in Java

Voorbeeld-I/O:

Input: { {'raj', 'kashup'}, {'rahul', 'singh'}, {'reshmi', 'dubey'}, {'rahul', 'jetli'} } Output: { {'rahul', 'jetli'}, {'rahul', 'singh'}, {'raj', 'kashup'}, {'reshmi', 'dubey'} } Input: { {'abc', 'last'}, {'pklz', 'yelp'}, {'rpng', 'note'}, {'ppza', 'xyz'} } Output: { {'abc', 'last'}, {'pklz', 'yelp'}, {'ppza', 'xyz'}, {'rpng', 'note'} }>

Java




wat is 10 van de 100
import> java.io.*;> import> java.util.*;> class> Pair>implements> Comparable {> >String firstName;> >String lastName;> >public> Pair(String x, String y)> >{> >this>.firstName = x;> >this>.lastName = y;> >}> >public> String toString()> >{> >return> '( '> + firstName +>' , '> + lastName +>' )'>;> >}> >@Override> public> int> compareTo(Pair a)> >{> >// if the string are not equal> >if> (>this>.firstName.compareTo(a.firstName) !=>0>) {> >return> this>.firstName.compareTo(a.firstName);> >}> >else> {> >// we compare lastName if firstNames are equal> >return> this>.lastName.compareTo(a.lastName);> >}> >}> }> public> class> GFG {> >public> static> void> main(String[] args)> >{> >int> n =>4>;> >Pair arr[] =>new> Pair[n];> >arr[>0>] =>new> Pair(>'raj'>,>'kashup'>);> >arr[>1>] =>new> Pair(>'rahul'>,>'singh'>);> >arr[>2>] =>new> Pair(>'reshmi'>,>'dubey'>);> >arr[>3>] =>new> Pair(>'rahul'>,>'jetli'>);> >// Sorting the array> >Arrays.sort(arr);> >// printing the> >// Pair array> >print(arr);> >}> >public> static> void> print(Pair[] arr)> >{> >for> (>int> i =>0>; i System.out.println(arr[i]); } } }>

>

>

Uitgang:

 Before Sorting: ( raj , kashup ) ( rahul , singh ) ( reshmi , dubey ) ( rahul , jetli ) After Sorting: ( rahul , jetli ) ( rahul , singh ) ( raj , kashup ) ( reshmi , dubey )>

In dit artikel hebben we door de gebruiker gedefinieerde paren met verschillende gegevenstypen gesorteerd met behulp van Java vergelijkbaar .