Java编程:判断字符串是否回文的两种方法
版权申诉
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()`方法以及双指针法。这些方法在实际编程中可根据个人偏好和需求选择使用。
2021-07-16 上传
2024-10-12 上传
2024-11-11 上传
2024-09-07 上传
2024-10-19 上传
2024-10-20 上传
2023-06-12 上传
小兔子平安
- 粉丝: 254
- 资源: 1940
最新资源
- Struts入门--按步骤一步步来就可以了
- 超图2000 说明书
- java笔试题(值得一看)
- C语言常用语法表.doc
- c语言堆和链表.doc
- CoreJava笔记
- ModBus协议(中文pdf文件)
- 基于空域LSB的数字图像加密算法
- Eclipse中文教程
- 关于char (*p)[] 和char p[]的问题
- 《JavaScript语言精髓与编程实践》精选版--动态函数式语言精粹
- RCP程序设计 pdf电子书
- intouch用户说明
- Algorithms in C++, Parts 1-4 (code)
- 敏捷开发:Development Build Grid
- 敏捷开发:电信领域敏捷开发经验分享