在 Java 中按字母顺序比较字符串
在 Java 中有多种方法可以比较两个或多个字符串,但如果你想按字典顺序(按字母顺序)比较字符串,请参阅这篇文章。字典顺序遵循字典中的单词排列。下面的示例展示了在 Java 中按字母顺序比较字符串的两种方法。
使用 compareTo()
按字母顺序比较字符串
在示例中,我们比较了几个字符串以查看结果是否正确。compareTo()
方法带有 String
类,因此我们可以用任何字符串调用它来与另一个字符串进行比较。下面我们将 s1
与 s2
、s3
与 s4
、s5
与 s6
等进行比较。
当我们使用 compareTo()
比较字符串时,该方法返回一个 int
值,该值告诉我们字符串应该放在之前或之后的位置,或者它们是否相等。例如,如果我们使用 s1.compare(s2)
将值为 apple
的 s1
与值为 orange
的 s2
进行比较,则 comparedResult
函数将得到一个负整数——这意味着 s1
值在 s2
之前。
如果 comparedResult
得到一个正整数,当 s3
与 s4
进行比较时,这意味着 s3
在 s4
之后,因为按字典顺序,大写字母在小写字母之前。
如果 compareTo()
方法返回零,则表示两个比较的字符串相等,如 s9
和 s10
。
class CompareStrings {
public static void main(String args[]) {
String s1 = "apple";
String s2 = "orange";
compareStrings(s1, s2);
String s3 = "apple";
String s4 = "Orange";
compareStrings(s3, s4);
String s5 = "sole";
String s6 = "soul";
compareStrings(s5, s6);
String s7 = "john";
String s8 = "johnson";
compareStrings(s7, s8);
String s9 = "one";
String s10 = "one";
compareStrings(s9, s10);
}
public static void compareStrings(String s1, String s2) {
int comparedResult = s1.compareTo(s2);
if (comparedResult > 0) {
System.out.println(s1 + " comes after " + s2);
} else if (comparedResult < 0) {
System.out.println(s1 + " comes before " + s2);
} else {
System.out.println(s1 + " is equal to " + s2);
}
}
}
输出:
apple comes before orange
apple comes after Orange
sole comes before soul
john comes before johnson
one is equal to one
使用传统方式按字母顺序比较字符串
在这个例子中,我们采用与前面的例子相同的输出相同的字符串,但方法不同。我们不使用任何类的方法,而是创建自己的方法。compareStrings()
是进行比较的方法。
在 compareStrings()
中,我们创建了一个循环,检查直到字符串 s1
和 s2
的结尾。在循环内部,我们首先使用 charAt()
获取字符串的字符并将其转换为 int
,这将返回一个 ASCII 值。我们对两个字符串都这样做,然后比较 ASCII 值。如果所有 ASCII 值都相等,则意味着两个字符串也相等。
如果 ASCII 值不同,那么我们使用 (int) s1.charAt(i) - (int) s2.charAt(i);
返回字符串的 ASCII 值之间的差异。在循环之后,我们检查字符串的长度,然后返回它们之间的差异。
最后,获取 compareStrings()
方法返回的 int
值并将其与字符串一起传递给 getComparisonResult()
函数,该函数打印结果是字符串应该在前面还是后面,或者它们是否是平等的。
class CompareStrings {
public static void main(String[] args) {
String s1 = "apple";
String s2 = "orange";
int getValue1 = compareStrings(s1, s2);
String s3 = "apple";
String s4 = "Orange";
int getValue2 = compareStrings(s3, s4);
String s5 = "sole";
String s6 = "soul";
int getValue3 = compareStrings(s5, s6);
String s7 = "john";
String s8 = "johnson";
int getValue4 = compareStrings(s7, s8);
String s9 = "one";
String s10 = "one";
int getValue5 = compareStrings(s9, s10);
getComparisonResult(getValue1, s1, s2);
getComparisonResult(getValue2, s3, s4);
getComparisonResult(getValue3, s5, s6);
getComparisonResult(getValue4, s7, s8);
getComparisonResult(getValue5, s9, s10);
}
public static int compareStrings(String s1, String s2) {
for (int i = 0; i < s1.length() && i < s2.length(); i++) {
if ((int) s1.charAt(i) == (int) s2.charAt(i)) {
continue;
} else {
return (int) s1.charAt(i) - (int) s2.charAt(i);
}
}
if (s1.length() < s2.length()) {
return (s1.length() - s2.length());
} else if (s1.length() > s2.length()) {
return (s1.length() - s2.length());
} else {
return 0;
}
}
private static void getComparisonResult(int value, String s1, String s2) {
if (value > 0) {
System.out.println(s1 + " comes after " + s2);
} else if (value < 0) {
System.out.println(s1 + " comes before " + s2);
} else {
System.out.println(s1 + " and " + s2 + " are equal");
}
}
}
输出:
apple comes before orange
apple comes after Orange
sole comes before soul
john comes before johnson
one and one are equal