Comparar cadenas por orden alfabético

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

Quiero comparar las dos cadenas anteriores por su orden alfabético (que en este caso "Proyecto" y luego "Sunject" como "P" viene antes de "S"). ¿Alguien sabe cómo hacer eso en Java?

Makky
fuente

Respuestas:

121

String.compareTo podría o no ser lo que necesita.

Eche un vistazo a este enlace si necesita un orden localizado de cadenas.

Buhb
fuente
8
Tenga en cuenta que String#compareTola comparación lexicográfica clasificará la "Z" mayúscula antes de la "a" minúscula. Si está alfabetizando cadenas de mayúsculas y minúsculas, necesita un orden sensible al entorno local. En caso de que el enlace al orden localizado de cadenas falle , lo que debe usar es java.text.Collator .
marcadores de duelo
41
También puede usarString#compareToIgnoreCase
Dori
1
También tiene que lidiar con la letra acentuada, consulte stackoverflow.com/a/12927962/2087666
Remi Morin
94

Eche un vistazo al String.compareTométodo.

s1.compareTo(s2)

De los javadocs:

El resultado es un entero negativo si este objeto String precede lexicográficamente a la cadena de argumentos. El resultado es un entero positivo si este objeto String sigue lexicográficamente a la cadena de argumentos. El resultado es cero si las cadenas son iguales; compareTo devuelve 0 exactamente cuando el método equals (Object) devolvería verdadero.

dogbane
fuente
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
fuente
7

Puede llamar al método compareTo de cualquiera de las cadenas (java.lang.String.compareTo). Esta característica está bien documentada en el sitio de documentación de Java .

Aquí hay un programa corto que lo demuestra:

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();
    }
}

Aquí hay una demostración en vivo que muestra que funciona: http://ideone.com/Drikp3

Vasiliy Sharapov
fuente
6

Para orden alfabético después de la nacionalización, utilice 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 obtener una lista de las configuraciones regionales admitidas, consulte Configuraciones regionales compatibles con JDK 8 y JRE 8 .

Ondra Žižka
fuente
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
fuente
0

Como sugirieron otros, puede usar String.compareTo(String).

Pero si está ordenando una lista de cadenas y necesita un Comparator, no tiene que implementarlo, puede usar Comparator.naturalOrder()o Comparator.reverseOrder().

arenaq
fuente