码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【LeetCode】5. Valid Palindrome·有效回文


    题目描述 

    英文版描述

    A phrase is a palindrome if, after converting all uppercase letters into lowercase letters and removing all non-alphanumeric characters, it reads the same forward and backward. Alphanumeric characters include letters and numbers. Given a string s, return true if it is a palindrome, or false otherwise.

    英文版地址

    https://leetcode.com/problems/valid-palindrome/https://leetcode.com/problems/valid-palindrome/

    中文版描述

    给定一个字符串 s ,验证 s 是否是 回文串 ,只考虑字母和数字字符,可以忽略字母的大小写。 本题中,将空字符串定义为有效的 回文串 。

    示例 1: 输入: s = "A man, a plan, a canal: Panama" 输出: true 解释:"amanaplanacanalpanama" 是回文串 示例 2: 输入: s = "race a car" 输出: false 解释:"raceacar" 不是回文串

    Constraints·提示:

    • 1 <= s.length <= 2 * 105

    • 字符串 s 由 ASCII 字符组成

    中文版地址

    https://leetcode.cn/problems/XltzEq/https://leetcode.cn/problems/XltzEq/

    解题思路

    先全部转小写字母(题目要求忽略大小写)然后先去除除了字母和数字的字符,首尾依次比较

    解题方法

    俺这版

    1. class Solution {
    2. public static boolean isPalindrome(String s) {
    3. String s1 = s.toLowerCase().replaceAll("[^a-z|0-9]", "");
    4. int length = s1.length();
    5. for (int i = 0; i < length; i++) {
    6. int j = length - i - 1;
    7. if(j <= i){
    8. break;
    9. }
    10. char c1 = s1.charAt(i);
    11. char c2 = s1.charAt(j);
    12. if (c1 != c2) {
    13. return false;
    14. }
    15. }
    16. return true;
    17. }
    18. }

    官方版

    筛选+比较

    1. class Solution {
    2. public boolean isPalindrome(String s) {
    3. StringBuffer sgood = new StringBuffer();
    4. int length = s.length();
    5. for (int i = 0; i < length; i++) {
    6. char ch = s.charAt(i);
    7. if (Character.isLetterOrDigit(ch)) {
    8. sgood.append(Character.toLowerCase(ch));
    9. }
    10. }
    11. StringBuffer sgood_rev = new StringBuffer(sgood).reverse();
    12. return sgood.toString().equals(sgood_rev.toString());
    13. }
    14. }

    双指针法

    1. class Solution {
    2. public boolean isPalindrome(String s) {
    3. StringBuffer sgood = new StringBuffer();
    4. int length = s.length();
    5. for (int i = 0; i < length; i++) {
    6. char ch = s.charAt(i);
    7. if (Character.isLetterOrDigit(ch)) {
    8. sgood.append(Character.toLowerCase(ch));
    9. }
    10. }
    11. int n = sgood.length();
    12. int left = 0, right = n - 1;
    13. while (left < right) {
    14. if (Character.toLowerCase(sgood.charAt(left)) != Character.toLowerCase(sgood.charAt(right))) {
    15. return false;
    16. }
    17. ++left;
    18. --right;
    19. }
    20. return true;
    21. }
    22. }

    总结

    我的方法看似和官方提供的双指针法很像,但是执行时间和内存消耗都要更多,特别是执行时间 》〉果然没有对比就没有伤害(╯﹏╰)

    刚开始我以为是后面比较时我用的String,官方用的StringBuffer,StringBuffer比String遍历快的原因,于是我把我代码中正则匹配后的的字符串赋值给了一个StringBuffer,然后使用该StringBuffer进行遍历,然并卵(-。-; 更慢了。。。

    ​But!当我把正则匹配换成了Character.isLetterOrDigit(),速度蹿蹿的~~

    原来字符串的正则匹配这么慢,欢迎知道原因的同学评论区踢我哦☆〜(ゝ。∂)

  • 相关阅读:
    【业务场景】用户连点
    自然语言处理 Paddle NLP - 文本语义相似度计算(ERNIE-Gram)
    C/C++新冠疫情死亡率 2020年9月电子学会青少年软件编程(C/C++)等级考试一级真题答案解析
    RTU通讯控制器S274如何操作
    Excelize 开源基础发布 2.8.1 版本,2024 年首个更新
    标准中文电码查询易语言代码
    基于 TLS 1.3的百度安全通信协议 bdtls 介绍
    爬虫01-爬虫基本原理讲解
    抓包分析 TCP 握手和挥手
    R语言caTools包进行数据划分、scale函数进行数据缩放、class包的knn函数构建K近邻分类器、table函数计算混淆矩阵
  • 原文地址:https://blog.csdn.net/aqin1012/article/details/125583663
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号