Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignoring cases.

For example,
"A man, a plan, a canal: Panama" is a palindrome.
"race a car" is not a palindrome.

Note:
Have you consider that the string might be empty? This is a good question to ask during an interview.

For the purpose of this problem, we define empty string as valid palindrome.

验证一个给定的字符串是否为回文,用两个指针分别指向字符的首尾,判断是否相同,相同就的都向中间移动1位,判断下一组,左指针小于右指针就一直循环。遇到标点符号就跳过,处理下一个。遇到大写字母就转换成小写字母。

Java:

class Solution {
public boolean isPalindrome(String s) {
char[] chs = s.toCharArray();
int left = 0, right = s.length() - 1;
while (left <= right) {
while (left < right && !Character.isLetterOrDigit(chs[left]))
left++;
while (left < right && !Character.isLetterOrDigit(chs[right]))
right--;
if (Character.toLowerCase(chs[left++]) != Character.toLowerCase(chs[right--]))
return false;
}
return true;
}
}

Java:

public class Solution {
public boolean isPalindrome(String s) {
int size = s.length(), i = 0, j = size - 1;
s = s.toLowerCase(); while (i < j) {
if (!(s.charAt(i) >= 'a' && s.charAt(i) <= 'z') && !(s.charAt(i) >= '0' && s.charAt(i) <= '9')) {
i++;
}
else if (!(s.charAt(j) >= 'a' && s.charAt(j) <= 'z') && !(s.charAt(j) >= '0' && s.charAt(j) <= '9')) {
j--;
}
else {
if (s.charAt(i) != s.charAt(j)) return false; i++;
j--;
}
}
return true;
}
}

Python:

class Solution:
def isPalindrome(self, s):
i, j = 0, len(s) - 1
while i < j:
while i < j and not s[i].isalnum():
i += 1
while i < j and not s[j].isalnum():
j -= 1
if s[i].lower() != s[j].lower():
return False
i, j = i + 1, j - 1
return True

C++:

class Solution {
public:
bool isPalindrome(string s) {
int left = 0, right = s.size() - 1 ;
while (left < right) {
if (!isalnum(s[left])) ++left;
else if (!isalnum(s[right])) --right;
else if ((s[left] + 32 - 'a') %32 != (s[right] + 32 - 'a') % 32) return false;
else {
++left; --right;
}
}
return true;
}
};

C++:

class Solution {
public:
bool isPalindrome(string s) {
int l = 0, r = s.size() - 1;
while(l <= r){
while(!isalnum(s[l]) && l < r) l++;
while(!isalnum(s[r]) && l < r) r--;
if(toupper(s[l]) != toupper(s[r])) return false;
l++, r--;
}
return true;
}
};

类似题目:

[LeetCode] 9. Palindrome Number 验证回文数字

[LeetCode] 5. Longest Palindromic Substring 最长回文子串

[LeetCode] 516. Longest Palindromic Subsequence 最长回文子序列

  

All LeetCode Questions List 题目汇总

  

最新文章

  1. call,apply,bind的用法
  2. Leetcode 15. 3Sum
  3. C语言简单文法
  4. infopath重复表格无法保存输入内容
  5. js学习
  6. QuickRun-快速运行助手
  7. DOS批处理不支持将UNC 路径作为当前目录的巧妙解决方案
  8. 烂泥:centos安装LVM方式
  9. 第三个Sprint完结工作 用场景来规划测试工作.
  10. Qt 按键长按的处理
  11. android-exploitme(八):内存保护
  12. Codeforces Round #332 (Div. 2) A. Patrick and Shopping 水题
  13. 算法(Algorithm)是什么?
  14. Python数据结构之注意事项
  15. 提取Jar2Exe源代码,JavaAgent监控法
  16. 2. svg学习笔记-svg中的坐标系统和viewbox
  17. mysql5 数据库连接丢失问题,autoReconnect=true不起作用
  18. [2017BUAA软工]第零次作业
  19. Windows 端口占用解决
  20. 方正 ignb路由器设置备份(自用笔记)

热门文章

  1. Justice(HDU6557+2018年吉林站+二进制)
  2. python学习之鼠标事件&amp;键盘事件
  3. 【http】认识HTTP
  4. PCA: PCA的具体实现过程
  5. 深入理解JVM内存分配和常量池
  6. How Open Source Became The Default Business Model For Software
  7. MySQL 开启慢查询日志与普通日志
  8. WinDbg 图形界面功能(三)
  9. Binding a Xamarin.Forms WebView to ReactiveUI View Model using Custom Type Converters
  10. HAVING 搜索条件在进行分组操作之后应用