判斷一個字符串是否是回文有幾種方法。
方法一:使用StringBuilder類的reverse方法
public static boolean isPalindrome(String str) {
StringBuilder sb = new StringBuilder(str);
return str.equals(sb.reverse().toString());
}
方法二:使用雙指針法
public static boolean isPalindrome(String str) {
int left = 0;
int right = str.length() - 1;
while (left < right) {
if (str.charAt(left) != str.charAt(right)) {
return false;
}
left++;
right--;
}
return true;
}
方法三:將字符串轉換為字符數組,然后分別比較對應位置的字符
public static boolean isPalindrome(String str) {
char[] arr = str.toCharArray();
int left = 0;
int right = arr.length - 1;
while (left < right) {
if (arr[left] != arr[right]) {
return false;
}
left++;
right--;
}
return true;
}
使用方法一或方法二可以判斷一個字符串是否是回文,使用方法三可以判斷一個字符數組是否是回文。