❤️❤️❤️ 欢迎来到我的博客。希望您能在这里找到既有价值又有趣的内容,和我一起探索、学习和成长。欢迎评论区畅所欲言、享受知识的乐趣!
推荐:数据分析螺丝钉的首页 格物致知 终身学习 期待您的关注
导航:
- LeetCode解锁1000题: 打怪升级之旅:每题都包括3-5种算法,以及详细的代码实现,刷题面试跳槽必备
- 漫画版算法详解:通过漫画的形式和动态GIF图片把复杂的算法每一步进行详细可视解读,看一遍就掌握
- python源码解读:解读python的源代码与调用关系,快速提升代码质量
- python数据分析可视化:企业实战案例:企业级数据分析案例与可视化,提升数据分析思维和可视化能力
- 程序员必备的数学知识与应用:全面详细的介绍了工程师都必备的数学知识
期待与您一起探索技术、持续学习、一步步打怪升级 欢迎订阅本专栏❤️❤️
题目描述
给定一个字符串 s
,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。
注意: 本题中,我们将空字符串定义为有效的回文串。
示例:
- 输入: “A man, a plan, a canal: Panama”
- 输出: True
- 输入: “race a car”
- 输出: False
方法一:双指针法
解题步骤
- 创建两个指针,分别指向字符串的开始和结束位置。
- 向中心移动两个指针,跳过非字母和数字的字符。
- 比较两个指针所指的字符,如果在任何时候字符不同,则字符串不是回文。
- 如果指针成功地相遇,则字符串是回文。
Python 示例
def isPalindrome(s: str) -> bool:
l, r = 0, len(s) - 1
while l < r:
while l < r and not s[l].isalnum():
l += 1
while l < r and not s[r].isalnum():
r -= 1
if s[l].lower() != s[r].lower():
return False
l += 1
r -= 1
return True
# Example usage
print(isPalindrome("A man, a plan, a canal: Panama")) # Output: True
print(isPalindrome("race a car")) # Output: False
算法分析
- 时间复杂度:O(n),其中 n 是字符串的长度,最坏情况下需要检查所有字符。
- 空间复杂度:O(1),只使用了固定的额外空间。
算法图解与说明
示例 "A man, a plan, a canal: Panama"
双指针分别从两端开始向中间靠拢,跳过非字母和数字的字符,依次比较:
A 与 a, m 与 m, a 与 a, n 与 n, ...
最终两指针相遇,确认为回文串。
方法二:过滤和反转字符串
解题步骤
- 使用字符串方法和列表推导过滤出字母和数字字符。
- 将过滤后的字符串转换为小写。
- 比较过滤后的字符串和它的反转,如果相同则是回文。
Python 示例
def isPalindrome(s: str) -> bool:
filtered_chars = [char.lower() for char in s if char.isalnum()]
return filtered_chars == filtered_chars[::-1]
# Example usage
print(isPalindrome("A man, a plan, a canal: Panama")) # Output: True
print(isPalindrome("race a car")) # Output: False
算法分析
- 时间复杂度:O(n),其中 n 是字符串的长度。
- 空间复杂度:O(n),存储了过滤后的字符串。
算法图解与说明
使用列表推导提取 "A man, a plan, a canal: Panama" 中的字母和数字:
"amanaplanacanalpanama"
比较该字符串与其反转:
"amanaplanacanalpanama" == "amanaplanacanalpanama"
确认为回文。
这两种方法都能有效地解决验证回文字符串的问题,方法一在空间上更优,而方法二在代码简洁性上有优势。
🌹🌹如果觉得这篇文对你有帮助的话,记得一键三连关注、赞👍🏻、收藏是对作者最大的鼓励,非常感谢 ❥(^_-)
❤️❤️作者知识有限,如有错误,请各位大佬评论区批评指正,不胜感激❥(^_-)