问题:
给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。
说明:本题中,我们将空字符串定义为有效的回文串。
示例 1:
输入: "A man, a plan, a canal: Panama"
输出: true
解释:"amanaplanacanalpanama" 是回文串
示例 2:
输入: "race a car"
输出: false
解释:"raceacar" 不是回文串
提示:
1 <= s.length <= 2 * 105
字符串 s 由 ASCII 字符组成
解答思路:
以下是使用 Java 实现验证回文串的代码:
public class Palindrome {
public boolean isPalindrome(String s) {
// 将字符串转换为小写,并去除非字母和数字字符
s = s.toLowerCase().replaceAll("[^a-zA-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;
}
public static void main(String[] args) {
String s1 = "A man, a plan, a canal: Panama";
String s2 = "race a car";
Palindrome palindrome = new Palindrome();
boolean isPalindrome1 = palindrome.isPalindrome(s1);
boolean isPalindrome2 = palindrome.isPalindrome(s2);
System.out.println(s1 + " 是回文串吗?" + isPalindrome1);
System.out.println(s2 + " 是回文串吗?" + isPalindrome2);
}
}
这段代码首先将输入的字符串转换为小写,并去除非字母和数字字符。然后,使用两个指针从字符串的两端向中间比较字符。如果在比较过程中发现不相等的字符,则返回 'false',表示不是回文串。如果比较完整个字符串都没有发现不相等的字符,则返回 'true',表示是回文串。
(文章为作者在学习java过程中的一些个人体会总结和借鉴,如有不当、错误的地方,请各位大佬批评指正,定当努力改正,如有侵权请联系作者删帖。)