题解 | #回文子串的数量#

回文子串的数量

https://www.nowcoder.com/practice/3e8b48c812864b0eabba0b8b25867738

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 *
 * @param str string字符串
 * @return int整型
 */
function Substrings(str) {
    return resolve2(str);
}

function resolve(str) {
    const N = str.length;
    const dp = Array(N).fill().map(() => Array(N).fill(false));
    let res = 0;
    for(let i = N - 1; i >= 0; i--) {
        for(let j = i; j < N; j++) {
            if(str[i] === str[j] && (j - i <= 1 || dp[i+1][j-1])) {
                res++;
                dp[i][j] = true;
            }
        }
    }

    return res;
}

function resolve2(str) {
    let res = 0;
    const N = str.length;

    const huiwen = (str, i, j) => {
        let count = 0;
        while(i >= 0 && j < N && str[i--] === str[j++]) {
            count++;
        }
        return count;
    }

    for(let i = 0; i < N; i++) {
        res += huiwen(str, i, i);
        res += huiwen(str, i, i + 1);
    }

    return res;
}


module.exports = {
    Substrings: Substrings,
};

双指针中心扩展法和动态规划时间复杂度一致,O(N²),双指针的空间复杂度是O(1),动归的空间复杂度是 O(N²)

全部评论

相关推荐

2025-12-15 14:25
云南大学 Java
lei22:入职可能会看学信网,最好别伪装,这个简历找实习肯定是够的,肯定会有收 28 届实习生的公司的,多投就行
点赞 评论 收藏
分享
2025-11-22 15:15
门头沟学院 Java
程序员花海:实习太简单了 学历可以的 实习描述应该是先介绍业务 再介绍技术 技术咋推动业务的 做到了啥收益 有没有做实验 实验组和对照组有什么不同 你最后学到了什么 有没有参与处理过线上问题 有没有参与过公司的code review 有没有参与过技术分享 这些都是可以在实习描述中写的 并且实习和项目不一样不会撞车 这个实习经历描述有点太偏项目了
我的简历长这样
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务