Java回文串
在Java中判断字符串是否为回文时,有一些需要注意的事项,下面是一些常见的问题和解决方案:
1. 回文字符串是指字符串从左到右和从右到左读取都是一样的字符串,在判断时需要注意大小写,即要判断 “A” 和 “a” 是否相等。可以使用 equalsIgnoreCase()
方法来比较。
2. 回文字符串的判断可以使用两个指针,分别从字符串的两端向中间移动,依次比较每个字符是否相等。可以使用 String.charAt()
方法获取每个字符。在比较时,需要注意字符串长度为奇数和偶数的情况。
3. 在实际使用中,如果需要判断字符串是否为回文,还可以使用 StringBuilder
类的 reverse()
方法将字符串反转,然后比较反转后的字符串是否和原字符串相等。但是需要注意,使用 StringBuilder
类生成一个新的字符串是比较耗费内存的,因此在内存不宽裕的情况下,这种方法不一定适用。
总之,在判断一个字符串是否为回文时,我们应该可以根据需要选择不同的方法,关键是保证方法正确、高效和良好的可读性。
例:有这样一类字符串,它们顺着看和倒着看是相同的数,例如:121、656、2332、ABCBA等,这样的字符串就称为回文串。编写一个Java程序,判断从键盘接收的字符串是否为回文串。
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
System.out.print("请输入一个字符串:");
String str = input.nextLine();
if (isPalindrome(str)) {
System.out.println(str + " 是回文串");
} else {
System.out.println(str + " 不是回文串");
}
}
// 判断一个字符串是否为回文串
public static boolean isPalindrome(String str) {
int len = str.length();
for (int i = 0; i < len / 2; i++) {
if (str.charAt(i) != str.charAt(len - 1 - i)) {
return false;
}
}
return true;
}
}