有效回文串
题目
给定一个字符串,判断其是否为一个回文串。只包含字母和数字,忽略大小写。
注意事项
你是否考虑过,字符串有可能是空字符串?这是面试过程中,面试官常常会问的问题。
在这个题目中,我们将空字符串判定为有效回文样例
“A man, a plan, a canal: Panama” 是一个回文。
“race a car” 不是一个回文。挑战
O(n) 时间复杂度,且不占用额外空间。
题解
同样是双指针问题,需注意的是此类问题需要明确那种字符被视为有效回文,如本题就只需处理数字和字母即可。
public class Solution {
/**
* @param s A string
* @return Whether the string is a valid palindrome
*/
public boolean isPalindrome(String s) {
int i = 0;
int j = s.length() - 1;
s = s.toLowerCase();
while (i < j)
{
while (!((s.charAt(i) >= 'a' && s.charAt(i) <= 'z') || (s.charAt(i) >= '0' && s.charAt(i) <= '9')) && i < j)
{
i++;
}
while (!((s.charAt(j) >= 'a' && s.charAt(j) <= 'z') || (s.charAt(j) >= '0' && s.charAt(j) <= '9')) && i < j)
{
j--;
}
if (i < j)
{
if (s.charAt(i) != s.charAt(j))
{
return false;
}
i++;
j--;
}
}
return true;
}
}
Last Update 2016.9.16
有效回文串判断
本文介绍了一种使用双指针法判断字符串是否为有效回文的方法。该方法仅考虑字母和数字字符,并忽略大小写差异。文章提供了一个具体的Java实现案例,能够处理包括空字符串在内的各种情况。
228

被折叠的 条评论
为什么被折叠?



