1. 程式人生 > >【LeetCode】#125驗證迴文串(Valid Palindrome)

【LeetCode】#125驗證迴文串(Valid Palindrome)

【LeetCode】#125驗證迴文串(Valid Palindrome)

題目描述

給定一個字串,驗證它是否是迴文串,只考慮字母和數字字元,可以忽略字母的大小寫。
說明:本題中,我們將空字串定義為有效的迴文串。

示例

示例 1:

輸入: “A man, a plan, a canal: Panama”
輸出: true

示例 2:

輸入: “race a car”
輸出: false

Description

Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignoring cases.
Note: For the purpose of this problem, we define empty string as valid palindrome.

Example

Example 1:

Input: “A man, a plan, a canal: Panama”
Output: true

Example 2:

Input: “race a car”
Output: false

解法

class Solution {
    public boolean isPalindrome(String s) {
        s = s.trim().toLowerCase();
        int n=0, m=s.length()-1;
        while(n<m){
            if((s.charAt(n)>57 && s.charAt(n)<97) || s.charAt(n)>122 || s.charAt(n)<48){
                n++;
                continue;
            }
            if((s.charAt(m)>57 && s.charAt(m)<97) || s.charAt(m)>122 || s.charAt(m)<48){
                m--;
                continue;
            }
            if(s.charAt(n)!=s.charAt(m))
                return false;
            n++;
            m--;
        }
        return true;
    }
}