【蓝桥杯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;
    }
};
相关推荐
皮卡丘のcoding5 小时前
蓝桥杯备赛练习题01
职场和发展·蓝桥杯
Hhyao6 小时前
2024第十五届蓝桥杯网安赛道省赛题目--cc(CyberChef)/crypto
蓝桥杯·密码学
不过四级不改名6776 小时前
蓝桥杯嵌入式uart,iic,adc_scan模版
职场和发展·蓝桥杯
清弦墨客6 小时前
【蓝桥杯】43697.机器人塔
python·蓝桥杯·程序算法
Joyner20187 小时前
python-leetcode-从中序与后序遍历序列构造二叉树
算法·leetcode·职场和发展
LNsupermali7 小时前
力扣257. 二叉树的所有路径(遍历思想解决)
算法·leetcode·职场和发展
雾月557 小时前
LeetCode LCR180文件组合
算法·leetcode·职场和发展
labmem110 小时前
Leetcode:541
算法·leetcode·职场和发展
今天也想MK代码13 小时前
写好简历的三个关键认知
面试·职场和发展
JNU freshman14 小时前
蓝桥杯思维训练营(一)
蓝桥杯