>>>题目:如果给定的字符串是回文,返回true,反之,返回false。如果一个字符串忽略标点符号、大小写和空格,正着读和反着读一模一样,那么这个字符串就是palindrome(回文)。注意你需要去掉字符串多余的标点符号和空格,然后把字符串转化成小写来验证此字符串是否为回文。
>>>题目框架:
function palindrome(str) {
// 请把你的代码写在这里
return true;
}
palindrome("eye");
>>>个人思路:
1.将字符串分割成为数组
var myStr=str.split("");
2.去除标点符号和空格
myStr = myStr.filter(function(val) {
return (val !== " " && val !== "," && val !== "." && val !== "?" && val !== ":" && val !== ";" && val !== "`" && val !== "'" && val !== "_" && val !== "/" && val !== "-" && val !== "\\" && val !== "" && val !== "\(" && val !== "\)");
});
3将数组组合为字符串
var myStr1=myStr.join("");
4.将所有字母转为小写形式
myStr1=myStr1.toLowerCase();
5.将字符串反转,比较反转前后是否相同
var myStr2=myStr.reverse();
myStr2=myStr2.join("");
myStr2=myStr2.toLowerCase();
if (myStr1.length !== myStr2.length) {
return false;
} else {
// 循环遍历数组的值进行比较
for (var i = 0; i < myStr1.length; i++) {
if (myStr1[i] !== myStr2[i]) {
return false;
}
}
return true;
}
>>>总体代码
function palindrome(str) {
// 请把你的代码写在这里
var myStr=str.split("");
myStr = myStr.filter(function(val) {
return (val !== " " && val !== "," && val !== "." && val !== "?" && val !== ":" && val !== ";" && val !== "`" && val !== "'" && val !== "_" && val !== "/" && val !== "-" && val !== "\\" && val !== "" && val !== "\(" && val !== "\)");
});
var myStr1=myStr.join("");
myStr1=myStr1.toLowerCase();
var myStr2=myStr.reverse();
myStr2=myStr2.join("");
myStr2=myStr2.toLowerCase();
//return myStr1;
// 判断数组的长度
if (myStr1.length !== myStr2.length) {
return false;
} else {
// 循环遍历数组的值进行比较
for (var i = 0; i < myStr1.length; i++) {
if (myStr1[i] !== myStr2[i]) {
return false;
}
}
return true;
}
}
palindrome("A man, a plan, a canal. Panama");
题目最后通过了,但是我感觉这样好像麻烦了,请问各位大神有没有简单的,用js基础写的,蟹蟹蟹蟹