给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。
说明:本题中,我们将空字符串定义为有效的回文串。
示例 1:
输入: "A man, a plan, a canal: Panama"
输出: true
示例 2:
输入: "race a car"
输出: false
解题思路:
1、筛选字符串,只留下数字和字母
2、设置两个变量分别从字符串头部和尾部向中间遍历,比较两者是否相同,出现不同即return false
代码:
/**
* @param {string} s
* @return {boolean}
*/
var isPalindrome = function(s) {
var reg = /\d*[a-z]*/gi;
var convertResult = s.match(reg).toString().replace(/,/g,'').toLowerCase();
var head = 0,
end = convertResult.length-1;
while(head <= end) {
if(convertResult[head++] != convertResult[end--]) {
return false;
}
}
return true;
};