【蓝桥杯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;
    }
};
相关推荐
wuhen_n8 小时前
LeetCode -- 1:两数之和(简单)
javascript·算法·leetcode·职场和发展
Jeremy爱编码10 小时前
leetcode课程表
算法·leetcode·职场和发展
元亓亓亓12 小时前
LeetCode热题100--152. 乘积最大子数组--中等
算法·leetcode·职场和发展
Jeremy爱编码13 小时前
leetcode热题腐烂的橘子
算法·leetcode·职场和发展
Swift社区17 小时前
LeetCode 458 - 可怜的小猪
算法·leetcode·职场和发展
falldeep21 小时前
LeetCode高频SQL50题总结
数据结构·数据库·sql·算法·leetcode·职场和发展
千寻girling1 天前
计算机组成原理-全通关源码-实验(通关版)---头歌平台
前端·面试·职场和发展·typescript·node.js
a努力。1 天前
字节Java面试被问:系统限流的实现方式
java·开发语言·后端·面试·职场和发展·golang
Binky6781 天前
力扣--回溯篇(2)
算法·leetcode·职场和发展
东东的脑洞1 天前
【面试突击】Redis 主从复制核心面试知识点
redis·面试·职场和发展