检查回文字符串
如果给定的字符串是回文,返回true
,反之,返回false
。
如果一个字符串忽略标点符号、大小写和空格,正着读和反着读一模一样,那么这个字符串就是palindrome(回文)。
注意你需要去掉字符串多余的标点符号和空格,然后把字符串转化成小写来验证此字符串是否为回文。
函数参数的值可以为"racecar"
,"RaceCar"
和"race CAR"
。
首先这道题,我们应该先要判断输入的字符串中,只需要a-z、A-Z或者数字0-9,
因此我们用正则表达式
/[^a-zA-Z0-9]/g
就可以解决第一个问题。
第二个问题就是回文,我们只需要将字符串切成两半,头和尾进行比较就可以了。
代码:
function palindrome(str) {
// 请把你的代码写在这里
//利用正则 和转为小写
str = str.replace(/[^a-zA-Z0-9]/g,'').toLowerCase();
// 取字符串一半长度
for(var i=0;i<str.length/2;i++){
// 比较
if(str[i] !== str[str.length-i-1]){
return false;
}
}
return true;
}
palindrome("0_0 (: /-\ :) 0-0");