#力扣: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
}
相关推荐
(●—●)橘子……1 分钟前
3643.垂直翻转子矩阵 练习理解
笔记·python·学习·算法·leetcode·矩阵
小白程序员成长日记3 分钟前
2025.12.10 力扣每日一题
算法·leetcode
立志成为大牛的小牛8 分钟前
数据结构——五十七、插入排序(王道408)
数据结构·笔记·程序人生·考研·算法
兩尛8 分钟前
猴子爬山od
算法·华为od
亭上秋和景清10 分钟前
计算器回调函数
c语言·数据结构·算法
青山的青衫11 分钟前
【优先级队列(堆)+排序】LeetCode hot100+面试高频
算法·leetcode·面试
第二只羽毛16 分钟前
基于Deep Web爬虫的当当网图书信息采集
大数据·开发语言·前端·爬虫·算法
Ayanami_Reii16 分钟前
详解Splay平衡树
数据结构·算法·线段树·主席树·持久化线段树
前端小白在前进22 分钟前
★力扣刷题:LRU缓存
spring·leetcode·缓存
JiaJZhong31 分钟前
560. 和为 K 的子数组
数据结构·算法