Comparando strings por ordem alfabética

101
String s1 = "Project";
String s2 = "Sunject";

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?

Makky
fonte

Respostas:

121

String.compareTo pode ou não ser o que você precisa.

Dê uma olhada neste link se precisar de ordenação localizada de strings.

Buhb
fonte
8
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 .
marcadores de duelo de
41
Você também pode usarString#compareToIgnoreCase
Dori
1
Você também terá que lidar com letras acentuadas, consulte stackoverflow.com/a/12927962/2087666
Remi Morin
94

Dê uma olhada no String.compareTométodo.

s1.compareTo(s2)

Dos javadocs:

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.

dogbane
fonte
33
String a = "..."; 
String b = "...";  

int compare = a.compareTo(b);  

if (compare < 0) {  
    //a is smaller
}
else if (compare > 0) {
    //a is larger 
}
else {  
    //a is equal to b
} 
Mdaguerre
fonte
7

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:

class StringCompareExample {
    public static void main(String args[]){
        String s1 = "Project"; String s2 = "Sunject";
        verboseCompare(s1, s2);
        verboseCompare(s2, s1);
        verboseCompare(s1, s1);
    }

    public static void verboseCompare(String s1, String s2){
        System.out.println("Comparing \"" + s1 + "\" to \"" + s2 + "\"...");

        int comparisonResult = s1.compareTo(s2);
        System.out.println("The result of the comparison was " + comparisonResult);

        System.out.print("This means that \"" + s1 + "\" ");
        if(comparisonResult < 0){
            System.out.println("lexicographically precedes \"" + s2 + "\".");
        }else if(comparisonResult > 0){
            System.out.println("lexicographically follows \"" + s2 + "\".");
        }else{
            System.out.println("equals \"" + s2 + "\".");
        }
        System.out.println();
    }
}

Aqui está uma demonstração ao vivo que mostra que funciona: http://ideone.com/Drikp3

Vasiliy Sharapov
fonte
6

Para ordem alfabética após a nacionalização, use Collator.

//Get the Collator for US English and set its strength to PRIMARY
Collator usCollator = Collator.getInstance(Locale.US);
usCollator.setStrength(Collator.PRIMARY);
if( usCollator.compare("abc", "ABC") == 0 ) {
    System.out.println("Strings are equivalent");
}

Para obter uma lista de localidades com suporte, consulte Localidades com suporte JDK 8 e JRE 8 .

Ondra Žižka
fonte
1
import java.io.*;
import java.util.*;
public class CandidateCode {
    public static void main(String args[] ) throws Exception {
       Scanner sc = new Scanner(System.in);
           int n =Integer.parseInt(sc.nextLine());
           String arr[] = new String[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]);
        }
   }
}
Malik Arman
fonte
0

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().

arenaq
fonte