回文字符串就是正读和反读都一样的字符串,比如 "noon"、"abcba"
怎么验证字符串是回文字符串呢?这里简要提供几种方法供参考:
先使用字符串的split方法转化成数组,然后利用数组翻转,最后再转化成新的字符串,两者比对判断
function checkStr(str) {
return str === str.split('').reverse().join('')
}
checkStr("noon"); //true
checkStr("noonl"); //false
将原有str进行倒序循环生成新str1,两者比对判断
function checkStr(str){
let len = str.length;
let str1 = "";
for(let i=len-1; i>=0;i--){
str1+=str[i];
}
return str1 === str
}
checkStr("noon"); //true
checkStr("noonl"); //false
使用字符串的charAt方法得到前后对称位置的字符,进行循环比对,将结果存入result_arr中,最终判断result_arr中是否含有不相等(false)的数据,若有,则该字符串不是回文字符串,反之,是回文字符串
function checkStr(str){
let len = str.length;
let result_arr = [];
for(let i=0; i<len;i++){
// 依次进行前后比对
const result = str.charAt(i) === str.charAt(len-1-i)
result_arr.push(result)
}
return result_arr.indexOf(false) === -1
}
checkStr("noon"); //true
checkStr("noonl"); //false