js判断回文字符串

回文字符串就是正读和反读都一样的字符串,比如 "noon"、"abcba"

怎么验证字符串是回文字符串呢?这里简要提供几种方法供参考:

  1. 先使用字符串的split方法转化成数组,然后利用数组翻转,最后再转化成新的字符串,两者比对判断

function checkStr(str) {
    return str === str.split('').reverse().join('')
}
checkStr("noon"); //true
checkStr("noonl"); //false
  1. 将原有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
  1. 使用字符串的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

猜你喜欢

转载自blog.csdn.net/m0_65489440/article/details/128946871