leetcode刷题62.验证回文串——Java版

Posted 一条coding

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leetcode刷题62.验证回文串——Java版相关的知识,希望对你有一定的参考价值。

⭐欢迎订阅《leetcode》专栏,每日一题,每天进步⭐

分享个字母大小写转换的方法:

  1. 统一转成大写:ch & 0b11011111 简写:ch & 0xDF
  2. 统一转成小写:ch | 0b00100000 简写:ch | 0x20

——leetcode此题热评

前言

哈喽,大家好,我是一条。

糊涂算法,难得糊涂

《糊涂算法》专栏上线倒计时——7天

Question

125. 验证回文串

难度:简单

给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。

说明:本题中,我们将空字符串定义为有效的回文串。

示例 1:

输入: "A man, a plan, a canal: Panama"
输出: true
解释:"amanaplanacanalpanama" 是回文串

示例 2:

输入: "race a car"
输出: false
解释:"raceacar" 不是回文串

Solution

双指针

  • 前后两个指针遍历,如果不相等,返回false
  • 注意去除标点符号。

Code

所有leetcode代码已同步至github

欢迎star

/**
 * @author 一条coding
 */
class Solution {
    public boolean isPalindrome(String s) {
        int n = s.length();
        int left = 0, right = n - 1;
        while (left < right) {
            while (left < right && !Character.isLetterOrDigit(s.charAt(left))) {
                ++left;
            }
            while (left < right && !Character.isLetterOrDigit(s.charAt(right))) {
                --right;
            }
            if (left < right) {
                if (Character.toLowerCase(s.charAt(left)) != Character.toLowerCase(s.charAt(right))) {
                    return false;
                }
                ++left;
                --right;
            }
        }
        return true;
    }
}

Result

复杂度分析

  • 时间复杂度:O(1)

🌈寻宝

⭐今天是坚持刷题更文的第54/100天

⭐各位的点赞、关注、收藏、评论、订阅就是一条创作的最大动力

⭐更多算法题欢迎关注专栏《leetcode》

为了回馈各位粉丝,礼尚往来,给大家准备了一些算法教学视频和电子书

需要的小伙伴可以点这里

以上是关于leetcode刷题62.验证回文串——Java版的主要内容,如果未能解决你的问题,请参考以下文章

leetcode刷题20.最长回文子串——Java版

验证回文串(LeetCode)Java&C++

验证回文串(LeetCode)Java&C++

Leetcode刷题Python131. 分割回文串

LeetCode-125. 验证回文串(java)

leetcode.字符串.125验证回文串-Java