【LeetCode】5. Valid Palindrome·有效回文

有目标就不怕路远。年轻人.无论你现在身在何方.重要的是你将要向何处去。只有明确的目标才能助你成功。没有目标的航船.任何方向的风对他来说都是逆风。因此,再遥远的旅程,只要有目标.就不怕路远。没有目标,哪来的劲头?一车尔尼雷夫斯基

导读:本篇文章讲解 【LeetCode】5. Valid Palindrome·有效回文,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

题目描述 

英文版描述

A phrase is a palindrome if, after converting all uppercase letters into lowercase letters and removing all non-alphanumeric characters, it reads the same forward and backward. Alphanumeric characters include letters and numbers. Given a string s, return true if it is a palindrome, or false otherwise.

英文版地址

https://leetcode.com/problems/valid-palindrome/【LeetCode】5. Valid Palindrome·有效回文https://leetcode.com/problems/valid-palindrome/

中文版描述

给定一个字符串 s ,验证 s 是否是 回文串 ,只考虑字母和数字字符,可以忽略字母的大小写。 本题中,将空字符串定义为有效的 回文串 。

示例 1: 输入: s = “A man, a plan, a canal: Panama” 输出: true 解释:”amanaplanacanalpanama” 是回文串 示例 2: 输入: s = “race a car” 输出: false 解释:”raceacar” 不是回文串

Constraints·提示:

  • 1 <= s.length <= 2 * 105

  • 字符串 s 由 ASCII 字符组成

中文版地址

https://leetcode.cn/problems/XltzEq/【LeetCode】5. Valid Palindrome·有效回文https://leetcode.cn/problems/XltzEq/

解题思路

先全部转小写字母(题目要求忽略大小写)然后先去除除了字母和数字的字符,首尾依次比较

解题方法

俺这版

【LeetCode】5. Valid Palindrome·有效回文

class Solution {
 public static boolean isPalindrome(String s) {
        String s1 = s.toLowerCase().replaceAll("[^a-z|0-9]", "");
        int length = s1.length();
        for (int i = 0; i < length; i++) {
            int j = length - i - 1;
            if(j <= i){
                break;
            }
            char c1 = s1.charAt(i);
            char c2 = s1.charAt(j);
            if (c1 != c2) {
                return false;
            }
        }
        return true;
    }
}

官方版

筛选+比较

【LeetCode】5. Valid Palindrome·有效回文

class Solution {
        public boolean isPalindrome(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());
    }
}

双指针法

【LeetCode】5. Valid Palindrome·有效回文

class Solution {
    public boolean isPalindrome(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));
            }
        }
        int n = sgood.length();
        int left = 0, right = n - 1;
        while (left < right) {
            if (Character.toLowerCase(sgood.charAt(left)) != Character.toLowerCase(sgood.charAt(right))) {
                return false;
            }
            ++left;
            --right;
        }
        return true;
    }
}

总结

我的方法看似和官方提供的双指针法很像,但是执行时间和内存消耗都要更多,特别是执行时间 》〉果然没有对比就没有伤害(╯﹏╰)

【LeetCode】5. Valid Palindrome·有效回文

刚开始我以为是后面比较时我用的String,官方用的StringBuffer,StringBuffer比String遍历快的原因,于是我把我代码中正则匹配后的的字符串赋值给了一个StringBuffer,然后使用该StringBuffer进行遍历,然并卵(-。-; 更慢了。。。

【LeetCode】5. Valid Palindrome·有效回文

​But!当我把正则匹配换成了Character.isLetterOrDigit(),速度蹿蹿的~~

【LeetCode】5. Valid Palindrome·有效回文

原来字符串的正则匹配这么慢,欢迎知道原因的同学评论区踢我哦☆〜(ゝ。∂)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/135422.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!