码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 力扣刷题笔记28——验证回文串/isalnum/逆序string


    上一篇:力扣刷题笔记26——最小的k个数/快速排序学习/快排与冒泡的时间复杂度

    文章目录

    • 题目:
    • 我的方法:
    • isalnum函数
    • 逆序string

    题目:

    如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。
    字母和数字都属于字母数字字符。
    给你一个字符串 s,如果它是 回文串 ,返回 true ;否则,返回 false 。
    
    • 1
    • 2
    • 3

    我的方法:

    前后指针,如果是回文串,那前后索引的结果肯定是一样的,否则遇到一个不一样的就直接返回false。

    class Solution {
    public:
        bool isPalindrome(string s) {
            int lens = s.length();
            if(lens==1) return true;//如果只有一个,那肯定是回文串
            int left = 0,right = lens-1;
            while(left<=right){
                //如果s[left]不是字母或数字,移到下一位
                if((tolower(s[left])-'a'>25||tolower(s[left])-'a'<0)&&(tolower(s[left])-'0'>9||tolower(s[left])-'0'<0)){
                     left++;
                     continue;
                }
                //如果s[right]不是字母或数字,移到下一位
                if((tolower(s[right])-'a'>25||tolower(s[right])-'a'<0)&&(tolower(s[right])-'0'>9||tolower(s[right])-'0'<0)){
                    right--;
                    continue;
                }
                //如果s[left]和s[right]一样,则各移动一位
                if(tolower(s[left])==tolower(s[right])){
                    left++;
                    right--;
                }
                else{//如果s[left]和s[right]不一样,则不是回文串
                    return false;
                }
            }
            return true;
        }
    };
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29

    不足:想不到合适的方法来确认是不是字母或数字,所以if语句看着比较复杂。

    isalnum函数

    功能:判断是否为数字或字母,如果是则返回非零值,否则返回0。

    	cout<<isalnum('a');
    	cout << isalnum('1');
    	cout << isalnum('0');
    	cout << isalnum('/');
    	cout << isalnum('=');
    	cout << isalnum(' ');
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    在这里插入图片描述

    逆序string

    如何得到一个逆序的string变量。
    (如果先得到只有数字和字母的字符串,再得到其逆序,也可以判断回文串。)

    	 string a = "da24r";
    	 string b(a.rbegin(), a.rend());
    	 cout << b;
    
    • 1
    • 2
    • 3

    在这里插入图片描述

  • 相关阅读:
    使用canvas实现时间轴上滑块的各种常用操作(仅供参考)
    RabbitMQ简单用法
    【计网】(一) 集线器、网桥、交换机、路由器等概念
    Elasticsearch 8.X:这个复杂的检索需求如何实现?
    推特自动发帖,快速提升人气
    37~python 字符串
    json序列化框架处理isXxx属性时的注意事项
    找单身狗。一个数组中只有两个数字出现一次,其他数字出现了两次,编写一个函数找出这两个只出现一次的数字
    Spring Data JPA 之 一对一,一对多,多对多 关系映射
    CMake日志与变量操作
  • 原文地址:https://blog.csdn.net/weixin_45034895/article/details/133029040
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号