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