#力扣:125. 验证回文串@FDDLC

125. 验证回文串

一、Java

java 复制代码
class Solution {
    public boolean isPalindrome(String s) {
        for (int l = 0, r = s.length() - 1; l < r; l++, r--) {
            while (l < r && !Character.isLetterOrDigit(s.charAt(l))) l++;
            while (l < r && !Character.isLetterOrDigit(s.charAt(r))) r--;
            if (l < r && Character.toLowerCase(s.charAt(l)) != Character.toLowerCase(s.charAt(r))) return false;
        }
        return true;
    }
}

二、C++

cpp 复制代码
#include <string>

using namespace std;

class Solution {
public:
    bool isPalindrome(string s) {
        for (int l = 0, r = s.size() - 1; l < r; l++, r--) {
            while (l < r && !isalnum(s[l])) l++;
            while (l < r && !isalnum(s[r])) r--;
            if (l < r && tolower(s[l]) != tolower(s[r])) return false;
        }
        return true;
    }
};

三、Python

python 复制代码
class Solution:
    def isPalindrome(self, s: str):
        l, r = 0, len(s) - 1
        while l < r:
            while l < r and not s[l].isalnum():
                l += 1
            while l < r and not s[r].isalnum():
                r -= 1
            if l < r and s[l].lower() != s[r].lower():
                return False
            l, r = l + 1, r - 1
        return True

四、JavaScript

javascript 复制代码
var isPalindrome = function(s) {
    for (let l = 0, r = s.length - 1; l < r; l++, r--) {
        while (l < r && !/[a-zA-Z0-9]/.test(s[l])) l++;
        while (l < r && !/[a-zA-Z0-9]/.test(s[r])) r--;
        if (l < r && s[l].toLowerCase() !== s[r].toLowerCase()) return false;
    }
    return true;
};

五、Go

Go 复制代码
package main

import "unicode"

func isPalindrome(s string) bool {
	for l, r := 0, len(s)-1; l < r; l, r = l+1, r-1 {
		for l < r && !unicode.IsDigit(rune(s[l])) && !unicode.IsLetter(rune(s[l])) {
			l++
		}
		for l < r && !unicode.IsDigit(rune(s[r])) && !unicode.IsLetter(rune(s[r])) {
			r--
		}
		if l < r && unicode.ToLower(rune(s[l])) != unicode.ToLower(rune(s[r])) {
			return false
		}
	}
	return true
}
相关推荐
lifallen10 分钟前
Hadoop MapReduce 任务/输入数据 分片 InputSplit 解析
大数据·数据结构·hadoop·分布式·算法
熙xi.1 小时前
数据结构 -- 哈希表和内核链表
数据结构·算法·散列表
Ghost-Face1 小时前
并查集提高——种类并查集(反集)
算法
董董灿是个攻城狮2 小时前
5分钟搞懂大模型微调的原始能力退化问题
算法
艾醒6 小时前
大模型面试题剖析:大模型微调与训练硬件成本计算
人工智能·后端·算法
啊嘞嘞?6 小时前
力扣(滑动窗口最大值)
算法·leetcode·职场和发展
快递鸟6 小时前
ISV系统开发中物流接口的第三方模块对接:技术选型与集成实践
算法
墨染点香6 小时前
LeetCode 刷题【53. 最大子数组和】
数据结构·算法·leetcode
2501_924879267 小时前
客流特征识别误报率↓76%!陌讯多模态时序融合算法在智慧零售的实战解析
大数据·人工智能·算法·目标检测·计算机视觉·视觉检测·零售
北京地铁1号线7 小时前
广告推荐模型2:因子分解机(Factorization Machines, FM)
人工智能·算法·推荐算法