【蓝桥杯Day1】:LCR 018. 验证回文串,left++<right--?

1:isalnum() 函数说明:

检查参数c,是否为英文字母或阿拉伯数字。

2.int toupper( int c),toupper():将字母转位大写。

3.int tolower( int c),tolower():将字母转为小写。

下面是我自己写的,感觉写的有点搓。

特别注意的就是,在判断是否满足是字母或者数字的时候,可能就会发生left小于right,然后这样就是错的,不满足题意的,应该返回true。所以就要判断一下。

cpp 复制代码
class Solution {
public:
    bool is_num(string& s,int n)
    {
        char c=s[n];
        if(c>='a'&&c<='z')
        {
            s[n]+='A'-'a';
            return true;
        }
            
        else if(c>='A'&&c<='Z')
            return true;
        else if(c>='0'&&c<='9')
            return true;
        return false;
    }

    bool isPalindrome(string s) {
        int left=0,right=s.size()-1;
        while(left<right)
        {
            while(!is_num(s,left)&&left<s.size()-1)  left++;
            while(!is_num(s,right)&&right>0)   right--;
            if(s[left]!=s[right])   break;
            left++;
            right--;
        }
        if(left>=right)
            return true;
        else
            return false;
    }
};

然后就是用函数的,我都没见过这种,属实是2G网络。

cpp 复制代码
class Solution {
public:
    bool isPalindrome(string s) {
        string sgood;
        for(auto& c:s)
        {
            if(isalnum(c))
                sgood+=tolower(c);
        }
        string sgood_r(sgood.rbegin(),sgood.rend());
        return sgood==sgood_r;
    }
};

直接逆转一下然后判断的代码少。但是还是练一下双指针吧。

哎,把++,--放whie右边括号,不对哈,虽然左边先判断--,然后再咋样,就是不应该哈。

cpp 复制代码
class Solution {
public:
    bool isPalindrome(string s) {
        string sgood;
        for(auto& c:s)
        {
            if(isalnum(c))
                sgood+=tolower(c);
        }
        int left=0,right=sgood.size()-1;
        while(left<right)
        {
            if(sgood[left]!=sgood[right])
                return false;
            ++left;
            --right;
        }
        return true;
    }
};
相关推荐
迷茫的启明星2 小时前
各职业在当前发展阶段,使用AI的舒适区与盲区
大数据·人工智能·职场和发展
嘻嘻哈哈樱桃9 小时前
俄罗斯套娃信封问题力扣--354
算法·leetcode·职场和发展
田梓燊9 小时前
2026/4/12 leetcode 1320
算法·leetcode·职场和发展
j_xxx404_9 小时前
力扣题型--链表(两数相加|两两交换链表中的节点|重排链表)
数据结构·c++·算法·leetcode·蓝桥杯·排序算法
米粒110 小时前
力扣算法刷题 Day 41(买卖股票)
算法·leetcode·职场和发展
结构化知识课堂11 小时前
产品经理面试:产品需求分析10题(政策解读、用户心理研究)含答案
面试·职场和发展·产品经理·需求分析·产品思维
wfbcg11 小时前
每日算法练习:LeetCode 36. 有效的数独 ✅
算法·leetcode·职场和发展
酉鬼女又兒12 小时前
零基础快速入门计算机组成原理:《DRAM 刷新方式小结 & SRAM/DRAM 优劣及主存缓存划分》
考研·职场和发展·电脑·计算机组成原理
测试秃头怪13 小时前
python&selenium自动化测试实战项目详解
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
像素猎人13 小时前
map<数据类型,数据类型> mp和unordered_map<数据类型,数据类型> ump的讲解,蓝桥杯OJ4567最大数目
c++·算法·蓝桥杯·stl·map