Java编程:判断字符串是否回文的两种方法

版权申诉
0 下载量 2 浏览量 更新于2024-08-11 收藏 1KB TXT 举报
这段Java代码提供了三种不同的方法来判断一个用户输入的字符串是否是回文。回文是指正读反读都相同的字符串,例如"level"、"madam"等。 第一段代码: ```java import java.util.Scanner; import java.lang.String; public class Main { public static void main(String[] args) { Scanner input = new Scanner(System.in); String S = input.nextLine(); String S1 = ""; for (int i = 0; i < S.length(); i++) { S1 = S.charAt(i) + S1; } if (S.equals(S1)) { System.out.print("Yes"); } else { System.out.print("No"); } input.close(); } } ``` 这个版本的代码首先通过`Scanner`从标准输入获取字符串,然后逐字符添加到`S1`的前面,形成一个新的字符串。最后比较原始字符串和反转后的字符串是否相等,如果相等,则输出"Yes",否则输出"No"。 第二段代码: ```java import java.util.Scanner; import java.util.StringBuffer; public class Main { public static void main(String[] args) { Scanner scan = new Scanner(System.in); String S = scan.next(); StringBuffer sb = new StringBuffer(S); // String s1 = sb.reverse().toString(); // 使用 StringBuffer 的 reverse() 方法 // System.out.println(s1); // 不需要输出反转字符串,直接与原字符串比较 String s = sb.reverse().toString(); if (s.equals(S)) { System.out.println("Yes"); } else { System.out.println("No"); } scan.close(); } } ``` 这段代码同样使用`Scanner`获取输入,但使用了`StringBuffer`来处理字符串反转。`StringBuffer`提供了`reverse()`方法直接反转字符串,然后将反转后的字符串与原字符串比较。 第三段代码: ```java import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner input = new Scanner(System.in); String str = input.next(); int i = 0, j = str.length() - 1, flag = 0; for (; i <= j; i++, j--) { if (str.charAt(i) != str.charAt(j)) { flag = 1; // 发现不匹配字符,设置标志 break; } } if (flag == 0) { System.out.println("Yes"); } else { System.out.println("No"); } input.close(); } } ``` 最后一个示例更简洁,通过两个指针分别从字符串两端向中间遍历,一旦发现不同字符就设置`flag`为1并结束循环。如果遍历完都没有发现不同字符,则输出"Yes",否则输出"No"。 总结起来,这些代码展示了Java编程中检查字符串是否为回文的不同方法,包括逐字符添加到新字符串、使用`StringBuffer`的`reverse()`方法以及双指针法。这些方法在实际编程中可根据个人偏好和需求选择使用。