面试经典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');
    }
}

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

相关推荐
码云骑士4 小时前
12-GIL不是性能杀手(下)-绕过GIL的三种方案与决策树
算法·决策树·机器学习
一只齐刘海的猫4 小时前
【Leetcode】无重复字符的最长子串
算法·leetcode·职场和发展
行智科技4 小时前
FAST-LIVO2 源码精读(二):环境搭建与编译避坑
算法·ubuntu·自动驾驶·slam
重生之我是Java开发战士4 小时前
【Java SE】多线程(三):单例模式,阻塞队列,线程池与定时器
java·javascript·单例模式
AI人工智能+电脑小能手4 小时前
【大白话说Java面试题 第115题】【并发篇】第15题:说一下悲观锁和乐观锁的区别?
java·开发语言·面试
插件开发4 小时前
vs2015 cuda c++ cdpSimplePrint范例,递归功能实现演示
linux·c++·算法
Tisfy4 小时前
LeetCode 2130.链表最大孪生和:转数组 / 快慢指针+链表翻转(O(1))
算法·leetcode·链表·题解
心之伊始4 小时前
Spring Boot Actuator + Micrometer 实战:自定义业务指标并接入 Prometheus 观测接口耗时
java·spring boot·prometheus·actuator·micrometer
Full Stack Developme4 小时前
Spring Integration 教程
java·后端·spring
摇滚侠4 小时前
MyBatis 入门到项目实战 MyBatis 分页插件 65-66
java·开发语言·sql·mybatis