Dizeleri alfabetik sıralarına göre karşılaştırma


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

Yukarıdaki iki dizeyi alfabetik sırasına göre karşılaştırmak istiyorum (bu durumda "Proje" ve ardından "Güneşte", "P", "S" 'den önce gelir). Java'da bunu nasıl yapacağını bilen var mı?

Yanıtlar:


122

String.compareTo ihtiyacınız olan şey olabilir veya olmayabilir.

Yerelleştirilmiş dizge sıralamasına ihtiyacınız varsa bu bağlantıya bir göz atın .


8
O Not String#compareTobireyin lexicographic karşılaştırma alt durumda önce sermaye 'Z' sıralanır 'a.' Karışık harfli dizeleri alfabetik sıralıyorsanız, yerel ayara duyarlı sıralamaya ihtiyacınız vardır. Dizelerin yerelleştirilmiş sıralamasına olan bağlantının kesilmesi durumunda , kullanılacak şey java.text.Collator'dır .
düello işaretçileri

41
Ayrıca şunları da kullanabilirsinizString#compareToIgnoreCase
Dori

1
Ayrıca vurgulu harfle uğraşmak zorundasınız bkz. Stackoverflow.com/a/12927962/2087666
Remi Morin

95

String.compareToYönteme bir göz atın .

s1.compareTo(s2)

Javadocs'tan:

Bu String nesnesi sözlükbilimsel olarak argüman dizesinden önce gelirse, sonuç negatif bir tamsayıdır. Bu String nesnesi sözlükbilimsel olarak argüman dizesini takip ediyorsa, sonuç pozitif bir tamsayıdır. Dizeler eşitse sonuç sıfırdır; CompareTo, equals (Object) yöntemi true döndürdüğünde tam olarak 0 döndürür.


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
} 

7

Her iki dizenin CompareTo yöntemini (java.lang.String.compareTo) çağırabilirsiniz. Bu özellik, java dokümantasyon sitesinde iyi bir şekilde belgelenmiştir .

İşte bunu gösteren kısa bir program:

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

İşte işe yaradığını gösteren canlı bir gösteri: http://ideone.com/Drikp3


6

Millileştirmeyi takip eden alfabetik sıra için kullanın 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");
}

Desteklenen yerel ayarların listesi için, bkz. JDK 8 ve JRE 8 Desteklenen Yerel Ayarlar .


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

0

Başkalarının önerdiği gibi kullanabilirsiniz String.compareTo(String) .

Ancak bir Dizeler listesini sıralıyorsanız ve bir dizeye ihtiyacınız Comparatorvarsa, onu uygulamak zorunda değilsiniz, Comparator.naturalOrder()veya kullanabilirsiniz Comparator.reverseOrder().

Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.