[Java·算法·简单] LeetCode 125. 验证回文串 详细解读

简介: [Java·算法·简单] LeetCode 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 是一个空字符串 "" 。

由于空字符串正着反着读都一样,所以是回文串。


提示

 

👉️ 力扣原文

 

class Solution {
    public boolean isPalindrome2(String s) {
        s=s.toLowerCase();
        s=s.replaceAll("[^a-z0-9]", "");
 
        int left = 0,right =s.length()-1;
        while(left<right){
            if(s.charAt(left)!=s.charAt(right)){
                return false;
            }
            left++;
            right--;
        }
        return true;
    }
    public boolean isPalindrome1(String s) {
        StringBuffer sgood = new StringBuffer();
        int length = s.length();
        for(int i=0;i<length;i++){
            char ch = s.charAt(i);
            if(Character.isLetterOrDigit(ch)){
                sgood.append(Character.toLowerCase(ch));
            }
        }
        StringBuffer sgood_rev=new StringBuffer(sgood).reverse();
        return sgood.toString().equals(sgood_rev.toString());
    }
}


详细解读

我这里用两种方法实现了一下

isPalindrome2这段代码实现了判断一个字符串是否为回文串的功能。以下是它的详细代码思路:


  1. 转换为小写字母: 首先,将输入的字符串 s 中的所有大写字母转换为小写字母,以确保大小写不影响回文串的判断结果。这是通过调用 s.toLowerCase() 方法实现的。
  2. 移除非字母数字字符: 接下来,使用正则表达式 [^a-z0-9] 匹配所有非字母数字字符,并将其替换为空字符串。这样做的目的是去除字符串中的所有非字母数字字符,只保留字母和数字。这是通过调用 s.replaceAll("[^a-z0-9]", "") 实现的。
  3. 判断是否为回文串: 现在,处理后的字符串已经去除了所有非字母数字字符,并且转换为小写字母。接着,使用双指针法来判断处理后的字符串是否为回文串。双指针 left 和 right 分别指向处理后字符串的起始和末尾位置。每次迭代中,比较 left 和 right 指向的字符是否相等,如果不相等,则返回 false,表明不是回文串。如果相等,则将 left 向右移动一位,将 right 向左移动一位,直到 left 不小于 right 为止。如果在这个过程中没有返回 false,则说明是回文串,返回 true。


这就是整段代码的详细思路,它首先对字符串进行预处理,然后使用双指针法进行回文串的判断。



isPalindrome1这段代码实现了判断一个字符串是否为回文串的功能。它的思路是:


  1. 创建一个 StringBuffer 对象 sgood,用于存储经过处理后的字符串。
  2. 遍历输入字符串 s,将其中的字母和数字字符转换为小写字符,并添加到 sgood 中。
  3. 创建一个新的 StringBuffer 对象 sgood_rev,用于存储 sgood 的逆序字符串。
  4. 判断 sgood 和 sgood_rev 是否相等,若相等则说明原始字符串 s 是回文串,返回 true;否则返回 false。


这个实现与之前给出的实现相似,只是使用了 StringBuffer 类来构建处理后的字符串,以及对字符是否为字母或数字的判断。这种实现方式也是正确的,能够有效地判断一个字符串是否为回文串。

相关文章
|
5天前
|
算法 Java C语言
C++和Java中的随机函数你玩明白了吗?内附LeetCode470.rand7()爆改rand10()巨详细题解,带你打败LeetCode%99选手
C++和Java中的随机函数你玩明白了吗?内附LeetCode470.rand7()爆改rand10()巨详细题解,带你打败LeetCode%99选手
|
5天前
|
算法 安全 Java
性能工具之 JMeter 自定义 Java Sampler 支持国密 SM2 算法
【4月更文挑战第28天】性能工具之 JMeter 自定义 Java Sampler 支持国密 SM2 算法
34 1
性能工具之 JMeter 自定义 Java Sampler 支持国密 SM2 算法
|
3天前
|
缓存 算法 Java
数据结构~缓存淘汰算法--LRU算法(Java的俩种实现方式,万字解析
数据结构~缓存淘汰算法--LRU算法(Java的俩种实现方式,万字解析
|
3天前
|
NoSQL 算法 Java
【redis源码学习】持久化机制,java程序员面试算法宝典pdf
【redis源码学习】持久化机制,java程序员面试算法宝典pdf
|
5天前
|
算法 TensorFlow 算法框架/工具
基于直方图的图像阈值计算和分割算法FPGA实现,包含tb测试文件和MATLAB辅助验证
这是一个关于图像处理的算法实现摘要,主要包括四部分:展示了四张算法运行的效果图;提到了使用的软件版本为VIVADO 2019.2和matlab 2022a;介绍了算法理论,即基于直方图的图像阈值分割,通过灰度直方图分布选取阈值来区分图像区域;并提供了部分Verilog代码,该代码读取图像数据,进行处理,并输出结果到&quot;result.txt&quot;以供MATLAB显示图像分割效果。
|
5天前
|
设计模式 算法 Java
[设计模式Java实现附plantuml源码~行为型]定义算法的框架——模板方法模式
[设计模式Java实现附plantuml源码~行为型]定义算法的框架——模板方法模式
|
5天前
|
搜索推荐 算法 Java
Java实现的常用八种排序算法
提到数据结构与算法,无法避免的一点就包含排序,熟练的掌握各种排序算法则是一个程序员必备的素质之一,除此之外,排序算法也是当下各大技术公司比较喜欢问的技术点,所以,就这一点JavaBuild整理了常见的8种排序算法
13 0
|
5天前
|
机器学习/深度学习 数据采集 算法
使用 Java 实现机器学习算法
【4月更文挑战第19天】Java在数据驱动时代为机器学习提供支持,具备丰富的数学和数据结构库,适用于实现线性回归、决策树、SVM和随机森林等算法。实现时注意数据预处理、模型选择、评估指标和可视化。利用Java的库和编程能力可构建高效模型,但需按问题需求选择合适技术和优化方法。
|
5天前
|
Oracle Java 关系型数据库
Java 开发者必备:JDK 版本详解与选择策略(含安装与验证)
Oracle Java SE 支持路线图显示,JDK 8(LTS)支持至2030年,非LTS版本如9-11每6个月发布且支持有限。JDK 11(LTS)支持至2032年,而JDK 17及以上版本现在提供免费商用许可。LTS版本提供长达8年的支持,每2年发布一次。Oracle JDK与OpenJDK有多个社区和公司构建版本,如Adoptium、Amazon Corretto和Azul Zulu,它们在许可证、商业支持和更新方面有所不同。个人选择JDK时,可考虑稳定性、LTS、第三方兼容性和提供商支持。
176 0
|
5天前
|
算法 计算机视觉 异构计算
基于直方图相似性的图像分类算法FPGA实现,包括tb测试文件和MATLAB辅助验证
该内容包含了一段关于图像处理算法的摘要,主要包括: 1. 展示了MATLAB和FPGA的测试结果图像,显示了图像读取完成的标志和相似性指标,其中图1与图2有较强相似性,图1与图3相似性较弱。 2. 算法使用的是vivado 2019.2和matlab 2022A版本。 3. 算法原理涉及图像直方图统计和直方图相似性度量,通过计算直方图的差异来衡量图像相似度,FPGA实现包括图像采集、直方图计算、比较和分类决策步骤。 4. 提供了一个部分核心Verilog程序,用于读取图像数据并在FPGA上进行直方图相似性计算。