利用正则表达式检测给定的字符是否是回文

原创 2016-11-12 11:44:26 477
摘要:如果给定的字符串是回文,返回true,反之,返回false。如果一个字符串忽略标点符号、大小写和空格,正着读和反着读一模一样,那么这个字符串就是palindrome(回文)。注意你需要去掉字符串多余的标点符号和空格,然后把字符串转化成小写来验证此字符串是否为回文。函数参数的值可以为"racecar","RaceCar"和"race CAR"

如果给定的字符串是回文,返回true,反之,返回false。

如果一个字符串忽略标点符号、大小写和空格,正着读和反着读一模一样,那么这个字符串就是palindrome(回文)。

注意你需要去掉字符串多余的标点符号和空格,然后把字符串转化成小写来验证此字符串是否为回文。

函数参数的值可以为"racecar","RaceCar"和"race CAR"。

关键代码:

去掉字符串中的标点符号和空白格。可以用str.replace()+正则表达式匹配。

var newStr = str.replace(/[\ |\~|`|\!|\@|\#|\$|\%|\^|\&|\*|\(|\)|\-|\_|\+|\=|\||\|\[|\]|\{|\}|\;|\:|\"|\'|\,|\<|\.|\>|\/|\?]/g,"");

完整代码如下:

function palindrome(str) {
  // Good luck!
  var newStr = str.replace(/[\ |\~|`|\!|\@|\#|\$|\%|\^|\&|\*|\(|\)|\-|\_|\+|\=|\||\|\[|\]|\{|\}|\;|\:|\"|\'|\,|\<|\.|\>|\/|\?]/g,"");

  var newNewStr = newStr.toLowerCase();//转换成小写
  var spl = newNewStr.split("");//分割字符串为数组
  var newSpl = spl.reverse();//翻转
  var newRel = newSpl.join("");//再次转成字符串
  if (newNewStr == newRel) {//比较
    return true;
  } else return false;
}

palindrome("eye");


发布手记

热门词条