125. 验证回文串

该代码片段展示了如何使用Go编程语言编写一个名为`funcisPalindrome`的函数,用于检查输入字符串是否是回文,通过逐字符比较并忽略大小写和非字母数字字符。
func isPalindrome(s string) bool {
    sz := len(s)
    head := 0
    tail := sz-1 

    for head < tail {
        headval := s[head] // uint8
        tailval := s[tail]

        if headval >= 'A' &&  headval <= 'Z' {
            headval = headval+ ('a'-'A')
        }
        if tailval >= 'A' &&  tailval <= 'Z' {
            tailval = tailval+ ('a'-'A')
        }

        if ! ((headval >= 'a' && headval <= 'z') ||  
            (headval >='0' && headval <='9')) {
            head ++ 
            continue
        } 
        if ! ((tailval >= 'a' && tailval <= 'z') ||  
            (tailval >='0' && tailval <='9')) {
            tail --
            continue
        } 

        if headval != tailval {
            return false
        }
        head++
        tail--
    }
    return true
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值