毕业_设计 2022-01-27 10:42 采纳率: 100%
浏览 35
已结题

用C++解决验证回文串问题

验证回文串
给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。

说明:本题中,我们将空字符串定义为有效的回文串。

示例 1:

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

输入: "race a car"
输出: false
解释:"raceacar" 不是回文串
提示:

1 <= s.length <= 2 * 10^5
字符串 s 由 ASCII 字符组成

  • 写回答

1条回答 默认 最新

  • 易小侠 新星创作者: C/C++技术领域 2022-01-27 11:11
    关注
    
    
    ```c++
    #include <bits/stdc++.h>
    using namespace std;
    class Solution
    {
    public:
        bool isPalindrome(string s)
        {
            int left = 0, right;
            if ((right = s.size()) == 0)
            {
                return true;
            }
            while (left < right)
            {
                while (left < right && !isalnum(s[left]))
                {
                    left++;
                }
                while (left < right && !isalnum(s[right]))
                {
                    right--;
                }
                if (left < right)
                {
                    if (tolower(s[left]) != tolower(s[right]))
                    {
                        return false;
                    }
                }
                left++;
                right--;
            }
            return true;
        }
    };
    
    

    ```

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 2月4日
  • 已采纳回答 1月27日
  • 创建了问题 1月27日