OJ:验证回文串 | C++ [string]

题目链接:125. 验证回文串 - 力扣(LeetCode)

题目内容:

如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。

字母和数字都属于字母数字字符。 (⭐注意审题!)

给你一个字符串 s,如果它是 回文串 ,返回 true ;否则,返回 false 。

示例 1:
输入: s = "A man, a plan, a canal: Panama"
输出:true
解释:"amanaplanacanalpanama" 是回文串。

示例 2:
输入:s = "race a car"
输出:false
解释:"raceacar" 不是回文串。

示例 3:
输入:s = " "
输出:true
解释:在移除非字母数字字符之后,s 是一个空字符串 "" 。
由于空字符串正着反着读都一样,所以是回文串。

注意

以下这个测试用例是“0p”不是“op
OJ:验证回文串 | C++ [string]_第1张图片

解:

class Solution {
public:
	static bool isPalindrome(const string& s) {
		string s_lower;
		s_lower.resize(s.size());
		int i = 0, j = 0;
		while (i < s.size())
		{
			if (isalpha(s[i])||isdigit(s[i]))
			{
				s_lower[j] = (char)tolower(s[i]);
				++j;
			}
			++i;
		}

		int left = 0, right = j-1;
		while (left < right)
		{
			if (s_lower[left++] != s_lower[right--])     
				return false;
		}
        return true;
	}
};

你可能感兴趣的:(C++,题,c++,开发语言,leetcode)