在 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
Rupam Saini is an android developer, who also works sometimes as a web developer., He likes to read books and write about various things.
LinkedIn