当前位置: 首页 > news >正文

125. 验证回文串 【简单题】

题目

如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。

字母和数字都属于字母数字字符。

给你一个字符串 s,如果它是 回文串 ,返回 true ;否则,返回 false 

示例 1:

输入: s = "A man, a plan, a canal: Panama"
输出:true
解释:"amanaplanacanalpanama" 是回文串。

示例 2:

输入:s = "race a car"
输出:false
解释:"raceacar" 不是回文串。

示例 3:

输入:s = " "
输出:true
解释:在移除非字母数字字符之后,s 是一个空字符串 "" 。
由于空字符串正着反着读都一样,所以是回文串。

思路一:筛选+判断

代码一

c++
class Solution {
public:bool isPalindrome(string s) {// 2023年9月22日 14:20// 思路:复制一个新字符串,遍历源字符串,满足条件则加入新字符串。//  判断:从0到一半,依次遍历,只要跟相应的字符相同即可string res;bool flag = false;int i;for (i = 0; i < s.length(); i++) {if ((s[i] >= 'a' && s[i] <= 'z') || (s[i] >= '0' && s[i] <= '9')) {res += s[i];}else if (s[i] >= 'A' && s[i] <= 'Z') {s[i] += 32;res += s[i];}}int len = res.length();if(len == 1){return true;}int j;for (j = 0; j < (len / 2); j++) {if (res[j] != res[len-1 - j]) {break;}}if (j == (len / 2)) {flag = true;}return flag;      }
};
python
class Solution:def isPalindrome(self, s: str) -> bool:res = ""    # 定义一个空字符串for ch in s:    // 对字符串s进行依次遍历,ch为遍历的当前字符if(ch.isalnum()):    // 如果当前字符是字母或数字res += ch.lower()    // 若当前字符是字母,则把它变为小写字母return res == res[::-1]    // 字符串反转,比较

答案提供的两个函数:

isalnum:

判断一个字符是否是字母或者(十进制)数字,若为字母或者数字,则返回True(非0值),否者返回False(0)

tolower、toupper

答案思路

http://www.lryc.cn/news/176142.html

相关文章:

  • 描述性统计分析
  • Visual Studio2019 C++ 编程问题集锦
  • 链表的回文判断
  • 281_JSON_两段例子的比较,哪一段更简洁、易懂、没有那么多嵌套
  • 想要精通算法和SQL的成长之路 - 最长递增子序列 II(线段树的运用)
  • java用easyexcel按模版导出
  • Servlet执行流程生命周期方法介绍体系结构、Request和Response的功能详解
  • 软件工程之总体设计
  • 监控员工电脑文件拷贝记录:电脑怎么看员工复制文件的历史记录
  • vue中request.js中axios请求和(若依)文件通用下载方法封装
  • 【大数据存储与处理】1. hadoop单机伪分布安装和集群安装
  • linux通过time命令统计代码编译时间
  • logback日志是怎么保证多线程输出日志线程安全的
  • 2022年统计用区划代码表SQL 01
  • EM@基本初等函数@幂和根式@指数函数
  • 时序预测 | MATLAB实现NGO-GRU北方苍鹰算法优化门控循环单元时间序列预测
  • element 二次确认框,内容自定义处理
  • 【软件设计师-中级——刷题记录4(纯干货)】
  • 9.24 校招 实习 内推 面经
  • 第二章:25+ Python 数据操作教程(第二十五节用 PYTHON 和 R 制作祝福圣诞节)持续更新
  • 你是怎么理解自动化测试的?理解自动化测试的目的和本质
  • 二十六、MySQL并发事务问题:脏读/不可重复读/幻读
  • RK3588平台开发系列讲解(项目篇)视频监控之RTMP推流
  • http基础教程(超详细)
  • Vue3 <script setup> 单文件组件 组合式 API 相关语法
  • 为什么说网络安全是IT行业最后的红利?是风口行业?
  • DD5 进制转换
  • 操作系统权限提升(二十七)之数据库提权-MySQL MOF提权
  • springcloud:四、nacos介绍+启动+服务分级存储模型/集群+NacosRule负载均衡
  • 人生第一个java项目 学生管理系统