Eu quero comparar as duas strings acima por sua ordem alfabética (que, neste caso, "Projeto" e "Sunject" como "P" vem antes de "S"). Alguém sabe fazer isso em Java?
Observe que String#compareToa comparação lexicográfica de irá classificar "Z" maiúsculo antes de "a" minúsculo. Se você estiver alfabetizando strings de maiúsculas e minúsculas, precisará de uma ordenação com base na localidade. No caso de o link para a ordenação localizada de strings ficar inativo, deve-se usar java.text.Collator .
O resultado é um número inteiro negativo se este objeto String precede lexicograficamente a string do argumento. O resultado é um número inteiro positivo se este objeto String segue lexicograficamente a string do argumento. O resultado é zero se as strings forem iguais; compareTo retorna 0 exatamente quando o método equals (Object) retornaria verdadeiro.
Para ordem alfabética após a nacionalização, use Collator.
//Get the Collator for US English and set its strength to PRIMARYCollator usCollator =Collator.getInstance(Locale.US);
usCollator.setStrength(Collator.PRIMARY);if( usCollator.compare("abc","ABC")==0){System.out.println("Strings are equivalent");}
import java.io.*;import java.util.*;publicclassCandidateCode{publicstaticvoid main(String args[])throwsException{Scanner sc =newScanner(System.in);int n =Integer.parseInt(sc.nextLine());String arr[]=newString[n];for(int i =0; i < arr.length; i++){
arr[i]= sc.nextLine();}for(int i =0; i <arr.length;++i){for(int j = i +1; j <arr.length;++j){if(arr[i].compareTo(arr[j])>0){String temp = arr[i];
arr[i]= arr[j];
arr[j]= temp;}}}for(int i =0; i <arr.length; i++){System.out.println(arr[i]);}}}
Como outros sugeriram, você pode usar String.compareTo(String).
Mas se você está classificando uma lista de Strings e precisa de um Comparator, não precisa implementá-lo, você pode usar Comparator.naturalOrder()ou Comparator.reverseOrder().
String#compareTo
a comparação lexicográfica de irá classificar "Z" maiúsculo antes de "a" minúsculo. Se você estiver alfabetizando strings de maiúsculas e minúsculas, precisará de uma ordenação com base na localidade. No caso de o link para a ordenação localizada de strings ficar inativo, deve-se usar java.text.Collator .String#compareToIgnoreCase
Dê uma olhada no
String.compareTo
método.Dos javadocs:
fonte
fonte
Você pode chamar o método compareTo de qualquer string (java.lang.String.compareTo). Este recurso está bem documentado no site de documentação java .
Aqui está um pequeno programa que demonstra isso:
Aqui está uma demonstração ao vivo que mostra que funciona: http://ideone.com/Drikp3
fonte
Para ordem alfabética após a nacionalização, use
Collator
.Para obter uma lista de localidades com suporte, consulte Localidades com suporte JDK 8 e JRE 8 .
fonte
fonte
Como outros sugeriram, você pode usar
String.compareTo(String)
.Mas se você está classificando uma lista de Strings e precisa de um
Comparator
, não precisa implementá-lo, você pode usarComparator.naturalOrder()
ouComparator.reverseOrder()
.fonte