java回文串

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

java回文串_第1张图片

你可能感兴趣的:(算法,Java,java,算法)