标签:
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.
RE
需要改正。。暂且
class Solution {
public:
    bool isPalindrome(string s) {
        //transform(s.begin(),s.end(),s.begin(),::tolower);
        if(s.size()==0) return true;
        auto left=s.begin();
        auto right=prev(s.end());
        
        while(left<right)
        {
            while(!isalpha(*left) && !isdigit(*left))  ++left;
            while(!isalpha(*right) && !isdigit(*right)) --right;
            if((*left==*right)||(tolower(*left)==tolower(*right)))
            {
                left++;
                right--;
            }
            else return false;
        }
        return true;
    }
};
LeetCode:Valid Palindrome(need update)
标签:
原文地址:http://www.cnblogs.com/xiaoying1245970347/p/4555470.html