用java语言写一个判断回文字符串的代码
时间: 2023-08-21 18:31:35 浏览: 41
下面是一个Java实现的例子,同样是将字符串反转,然后与原字符串进行比较,如果两个字符串相同,则原字符串是回文字符串:
```java
public class Palindrome {
public static boolean isPalindrome(String s) {
String reversed = new StringBuilder(s).reverse().toString();
return s.equals(reversed);
}
public static void main(String[] args) {
String s = "racecar";
if (isPalindrome(s)) {
System.out.println(s + " is a palindrome");
} else {
System.out.println(s + " is not a palindrome");
}
}
}
```
在`isPalindrome`方法中,我们使用了`StringBuilder`类将原字符串反转,然后将反转后的字符串与原字符串进行比较。在`main`方法中,我们调用了`isPalindrome`方法,并根据返回值输出相应的结果。
相关问题
java判断字符串是否为回文
要判断一个字符串是否是回文,可以使用双指针的方法来比较字符串的首尾字符。具体的做法是,定义两个指针,一个指向字符串的起始位置,另一个指向字符串的末尾位置。然后,不断地比较两个指针所指向的字符是否相等,如果都相等,则将两个指针分别向中间移动一位,继续比较;如果有一个不相等,则说明字符串不是回文。当两个指针相遇时,表示已经比较完整个字符串,且所有字符都相等,所以字符串是回文。
下面是使用Java语言实现的判断字符串是否是回文的代码示例:
```java
public boolean isPalindrome(String s) {
if (s == null || s.length() == 0) {
return true;
}
// 将字符串转换为小写,并去除非字母和数字的字符
s = s.toLowerCase().replaceAll("[^a-z0-9]", "");
int left = 0;
int right = s.length() - 1;
while (left < right) {
if (s.charAt(left) != s.charAt(right)) {
return false;
}
left++;
right--;
}
return true;
}
```
判断是否为回文字符串
以下是Java语言实现判断是否为回文字符串的代码:
```java
public boolean isPalindrome(String str) {
boolean result = true;
for (int i = 0; i < str.length() / 2; i++) {
if (!(str.charAt(i) == str.charAt(str.length() - i - 1))) {
result = false;
break;
}
}
return result;
}
```
该方法的实现思路是:从字符串的两端开始,依次比较对应位置的字符是否相等,如果有不相等的字符,则该字符串不是回文字符串。需要注意的是,由于回文字符串的特殊性质,只需要比较字符串的前一半和后一半即可,因此循环次数为字符串长度的一半。