[java] 알파벳 순서로 문자열 비교

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

위의 두 문자열을 알파벳 순서로 비교하고 싶습니다 (이 경우 “Project”다음에 “Sunject”를 “P”가 “S”앞에옵니다). 누구든지 Java로 수행하는 방법을 알고 있습니까?



답변

String.compareTo 필요한 것일 수도 있고 아닐 수도 있습니다.

현지화 된 문자열 순서가 필요한 경우이 링크를 살펴보십시오 .


답변

String.compareTo방법을 살펴보십시오 .

s1.compareTo(s2)

javadocs에서 :

이 String 객체가 사전 식으로 인수 문자열 앞에 오는 경우 결과는 음의 정수입니다. 이 String 객체가 사전 식으로 인수 문자열을 따르는 경우 결과는 양의 정수입니다. 문자열이 같으면 결과는 0입니다. compareTo는 equals (Object) 메서드가 true를 반환 할 때 정확히 0을 반환합니다.


답변

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
} 


답변

문자열의 compareTo 메소드 (java.lang.String.compareTo)를 호출 할 수 있습니다. 이 기능은 Java 설명서 사이트에 잘 설명 되어 있습니다 .

다음은이를 보여주는 짧은 프로그램입니다.

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

다음은 작동을 보여주는 라이브 데모입니다. http://ideone.com/Drikp3


답변

국가 화 이후의 알파벳 순서는 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");
}

지원되는 로케일 목록은 JDK 8 및 JRE 8 지원 로케일을 참조하십시오 .


답변

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


답변

다른 사람들이 제안했듯이 String.compareTo(String) .

그러나 문자열 목록을 정렬하고 있고.이 필요한 경우 Comparator구현할 필요가 없으며 Comparator.naturalOrder()또는 을 사용할 수 있습니다 Comparator.reverseOrder().