面试经典150题——验证回文串

面试经典150题 day25

      • 题目来源
      • 我的题解
        • [方法一 双指针](#方法一 双指针)
        • [方法二 双指针 空间优化](#方法二 双指针 空间优化)

题目来源

力扣每日一题;题序:125

我的题解

方法一 双指针

首先去除掉字符串中的无用字符,并将英文字符转换为小写,然后使用双指针来判断是否是回文串。
时间复杂度 :O(n)
空间复杂度:O(n)

java 复制代码
public boolean isPalindrome(String s) {
    s=trimAndToLower(s);
    int n=s.length();
    int left=0,right=n-1;
    while(left<right){
        if(s.charAt(left++)!=s.charAt(right--)){
            return false;
        }
    }
    return true;
}
public String trimAndToLower(String s){
    StringBuilder sb=new StringBuilder();
    int n=s.length();
    for(int i=0;i<n;i++){
        char ch=s.charAt(i);
        if((ch>='a'&&ch<='z')||(ch>='0'&&ch<='9')){
            sb.append(ch);
        }else if(ch>='A'&&ch<='Z'){
            sb.append((char)(ch-'A'+'a'));
        }
    }
    return sb.toString();
}
方法二 双指针 空间优化

不再去删除无效字符,并将英文字符转为小写。而是在遍历过程中直接判断。
时间复杂度:O(n)

空间复杂度:O(1)

java 复制代码
public boolean isPalindrome(String s) {
    int n=s.length();
    int left=0,right=n-1;
    while(left<right){
        while(left<right&&!isUsedChar(s.charAt(left))){
            left++;
        }
        while(left<right&&!isUsedChar(s.charAt(right))){
            right--;
        }
        if(toLower(s.charAt(left++))!=toLower(s.charAt(right--))){
            return false;
        }
    }
    return true;
}
public boolean isUsedChar(char ch){
    return (ch>='a'&&ch<='z')||(ch>='0'&&ch<='9')||(ch>='A'&&ch<='Z');
}
public char toLower(char ch){
    if((ch>='a'&&ch<='z')||(ch>='0'&&ch<='9')){
        return ch;
    }else{
        return (char)(ch-'A'+'a');
    }
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

相关推荐
毕设源码-钟学长10 分钟前
【开题答辩全过程】以 浮生馆汉服租赁管理系统为例,包含答辩的问题和答案
android·java·tomcat
90后小陈老师10 分钟前
用户管理系统 07 项目前端初始化 | 新手实战 | 期末实训 | Java+SpringBoot+Vue
java·前端·spring boot
WWZZ202518 分钟前
快速上手大模型:深度学习5(实践:过、欠拟合)
人工智能·深度学习·神经网络·算法·机器人·大模型·具身智能
Coder-coco22 分钟前
点餐|智能点餐系统|基于java+ Springboot的动端的点餐系统小程序(源码+数据库+文档)
java·vue.js·spring boot·小程序·论文·毕设·电子点餐系统
Halo_tjn24 分钟前
Set集合专项实验
java·开发语言·前端·python
司铭鸿41 分钟前
图论中的协同寻径:如何找到最小带权子图实现双源共达?
linux·前端·数据结构·数据库·算法·图论
嘟嘟w1 小时前
Spring 核心注解深度分析
java·后端·spring
9***Y481 小时前
Java开发工具IntelliJ IDEA技巧
java·开发语言·intellij-idea
Java爱好狂.1 小时前
2025全年Java面试真题总结!
java·jvm·高并发·多线程·java面试·后端开发·java八股文
Charles_go2 小时前
C#中级39、什么是依赖注入设计模式
java·设计模式·c#