valid-palindrome

https://www.nowcoder.com/practice/b4dc0f1ee20448fca1f387fb1546f43f?tpId=46&tqId=29055&tPage=2&rp=2&ru=/ta/leetcode&qru=/ta/leetcode/question-ranking

反思:又犯了字符加空格的错误,编译器不会报字符里面有空格的错误。。。。

和普通的判断回文数一样,只不过判断之前得判断字符是不是数字或者字母即可。


class Solution {
public:
    bool isPalindrome(string s) {
        int n =s.length();
		if(n <= 0)
			return true;

		
		int left = 0, right = n - 1;

		while(left < right){
			
			//字符不是数字或者字母
			if(( (s[left] >= '0' && s[left] <= '9') || (s[left] >= 'a'&& s[left] <= 'z') || (s[left] >= 'A' && s[left] <= 'Z') ) == false){
					
					left++;
					continue;
			}
			//同上
			if(( (s[right] >= '0' && s[right] <= '9') || (s[right] >= 'a' && s[right] <= 'z') || (s[right] >= 'A' && s[right] <= 'Z') ) == false ){
					right--;
					continue;
			}

			//相等或者是大小写判断下一个
			if(s[left] == s[right] || abs(s[left] - s[right] ) == 32){
				left++;
				right--;
				continue ;
			}

			return false;

		
		}

		return true;

    }
};

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值