[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 类来构建处理后的字符串,以及对字符是否为字母或数字的判断。这种实现方式也是正确的,能够有效地判断一个字符串是否为回文串。

相关文章
|
16天前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
50 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
26天前
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
37 0
|
14天前
|
算法
每日一道算法题(Leetcode 20)
每日一道算法题(Leetcode 20)
20 2
|
22天前
|
存储 网络协议 前端开发
在 Java 中如何完全验证 URL
在 Java 中如何完全验证 URL
65 8
|
18天前
|
算法 搜索推荐 Java
java 后端 使用 Graphics2D 制作海报,画echarts图,带工具类,各种细节:如头像切割成圆形,文字换行算法(完美实验success),解决画上文字、图片后不清晰问题
这篇文章介绍了如何使用Java后端技术,结合Graphics2D和Echarts等工具,生成包含个性化信息和图表的海报,并提供了详细的代码实现和GitHub项目链接。
66 0
java 后端 使用 Graphics2D 制作海报,画echarts图,带工具类,各种细节:如头像切割成圆形,文字换行算法(完美实验success),解决画上文字、图片后不清晰问题
|
18天前
|
算法 Java Linux
java制作海报一:java使用Graphics2D 在图片上写字,文字换行算法详解
这篇文章介绍了如何在Java中使用Graphics2D在图片上绘制文字,并实现自动换行的功能。
47 0
|
20天前
【LeetCode 40】98.验证二叉搜索树
【LeetCode 40】98.验证二叉搜索树
10 0
|
26天前
|
算法 Java 测试技术
数据结构 —— Java自定义代码实现顺序表,包含测试用例以及ArrayList的使用以及相关算法题
文章详细介绍了如何用Java自定义实现一个顺序表类,包括插入、删除、获取数据元素、求数据个数等功能,并对顺序表进行了测试,最后还提及了Java中自带的顺序表实现类ArrayList。
15 0
|
3月前
|
设计模式 缓存 算法
揭秘策略模式:如何用Java设计模式轻松切换算法?
【8月更文挑战第30天】设计模式是解决软件开发中特定问题的可重用方案。其中,策略模式是一种常用的行为型模式,允许在运行时选择算法行为。它通过定义一系列可互换的算法来封装具体的实现,使算法的变化与客户端分离。例如,在电商系统中,可以通过定义 `DiscountStrategy` 接口和多种折扣策略类(如 `FidelityDiscount`、`BulkDiscount` 和 `NoDiscount`),在运行时动态切换不同的折扣逻辑。这样,`ShoppingCart` 类无需关心具体折扣计算细节,只需设置不同的策略即可实现灵活的价格计算,符合开闭原则并提高代码的可维护性和扩展性。
59 2
|
7天前
|
算法 安全 数据安全/隐私保护
基于game-based算法的动态频谱访问matlab仿真
本算法展示了在认知无线电网络中,通过游戏理论优化动态频谱访问,提高频谱利用率和物理层安全性。程序运行效果包括负载因子、传输功率、信噪比对用户效用和保密率的影响分析。软件版本:Matlab 2022a。完整代码包含详细中文注释和操作视频。