验证回文串--leetcode第125题
2019-04-14 18:25
337 查看
验证一个字符串是否为回文
题目:给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。
示例1:
输入: “A man, a plan, a canal: Panama”
输出: true
示例2:
输入: “race a car”
输出: false
思路:
1、先进行判空
2、分别从前往后、从后往前寻找字符串里的有效字符或数字(跳过空格)
3、前后分别每找到一次有效的字符或数字,便进行一次判断
4、用while循环进行,直至不满足条件:begin>end,则结束
代码:
class Solution { public: bool isPalindrome(string s) { //判空 if (s.empty()) return true; int begin = 0; int end = s.size() - 1; // char* p = (char*)s.c_str(); while(begin < end) { //从前往后找有效字符(数字和字符) while(begin != end) { if( IsNumberLetters(s[begin])) break; else ++begin; } //从后往前找有效字符(数字和字符) while(begin != end) { if(IsNumberLetters(s[end])) break; else --end; } //验证是否相等 if(begin < end) { if((s[begin] + 32 - 'a') % 32 != (s[end] + 32 - 'a') % 32) return false; ++begin; --end; } } return true; } bool IsNumberLetters(char c) { if(c >= '0' && c <= '9' || c >= 'A' && c <= 'Z' || c >= 'a' && c <= 'z') { return true; } return false; } };
相关文章推荐
- 验证回文串 - LeetCode
- Leetcode题库 - 验证回文串(java语言版)
- [leetcode]验证回文串[javascript]
- leetcode-125. Valid Palindrome(验证含有标点符号String是否为回文串)
- LeetCode - 125. 验证回文串
- leetcode 125 验证回文串
- Python LeetCode(125.验证回文串)
- LeetCode 125.验证回文串
- LeetCode 125. 验证回文串
- Leetcode:125.验证回文串
- Leetcode刷题28-125.验证回文串(C++)
- LeetCode-125.验证回文串(相关话题:字符串)
- leetcode 第125题 valid Palindrome
- [LeetCode] Palindrome Partitioning II 拆分回文串之二
- 利用python 完成 leetcode132 分割回文串 II
- 【LeetCode】Validate Binary Search Tree 验证二叉查找树 - Medium+
- 利用python 完成 leetcode131 分割回文串
- LeetCode 20. Valid Parentheses--验证括号是否有效
- [LeetCode] 409. 最长回文串
- leetcode:Palindrome Partitioning (字符串分割成回文串的所有方式) 【面试算法题】