每日一练(40):验证回文串

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

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


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


示例 1:


输入: "A man, a plan, a canal: Panama"

输出: true


解释:"amanaplanacanalpanama" 是回文串


示例 2:


输入: "race a car"

输出: false


解释:"raceacar" 不是回文串


提示:


1 <= s.length <= 2 * 105


字符串 s 由 ASCII 字符组成


来源:力扣(LeetCode)


链接:https://leetcode-cn.com/probl...


方法一:字符串预处理 + 双指针


思路分析


isalnum:判断字符变量c是否为字母或数字,若是则返回非零,否则返回零。

tolower:把字母字符转换成小写,非字母字符不做出处理


1.先把字符串s做处理


2.双指针判断,左指针指向第一个位置,右指针指向最后一个位置,依次判断是否相同


bool isPalindrome(string s) {
    string str;
    for (const char &ch : s) {
        if (isalnum(ch)) {
            str.push_back(tolower(ch));// 将数字和字母保存在 str 中,大写字母转换成小写
        }
    }
    // 左指针指向第一个位置,右指针指向最后一个位置
    // 依次比较是否相同
    int l = 0, r = str.size() - 1;
    while (l < r) {
        if (str[l] != str[r]) {
            return false;
        }
        l++;
        r--;
    }
    return true;
}


方法二:筛选 + 判断


思路分析


对字符串 s 进行一次遍历,并将其中的字母和数字字符进行保留,放在另一个字符串 sgood 中。这样我们只需要判断 sgood 是否是一个普通的回文串即可


使用语言中的字符串翻转 API 得到 sgood 的逆序字符串 sgood_rev


bool isPalindrome(string s) {
    string sgood;
    for (const char &ch : s) {
        if (isalnum(ch)) {
            sgood.push_back(tolower(ch));// 将数字和字母保存在 sgood 中,大写字母转换成小写
        }
    }
    string sgood_rev(sgood.rbegin(), sgood.rend());// API逆转字符串
    return sgood == sgood_rev;
}


目录
相关文章
|
5月前
力扣经典150题第二十五题:验证回文串
力扣经典150题第二十五题:验证回文串
35 0
|
5月前
|
canal 算法 数据可视化
LeetCode 125题:验证回文串
LeetCode 125题:验证回文串
|
6月前
leetcode-125:验证回文串
leetcode-125:验证回文串
52 0
|
6月前
|
算法
算法编程(六):验证回文串
算法编程(六):验证回文串
49 0
|
6月前
|
canal 算法 前端开发
前端算法专栏-数组-125. 验证回文串
前端算法专栏-数组-125. 验证回文串
182 0
LeetCode150道面试经典题--验证回文串(简单)
如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。
72 0
|
人工智能
Leecode 680 验证回文串 II 双指针法
第一次报错是因为没有判断删除一个字符后的情况 第二次报错是因为没有添加是删除一个字符而不是删除多个字符能不能构成回文串的条件 第三次报错是因为没有考虑先删除左边还是右边的问题,有些奇葩它先删除左边不可以通过,得先删除右边
|
canal
LeetCode 125. 验证回文串
LeetCode 125. 验证回文串
89 0
LeetCode 125. 验证回文串
LeetCode 680. 验证回文字符串 Ⅱ
给定一个非空字符串 s,最多删除一个字符。判断是否能成为回文字符串。
73 0