求解牛客网的一道lcs算法题

发布于 2022-09-04 14:50:06 字数 1131 浏览 9 评论 0

题目地址

求解我的答案为什么不能过通过

nk1:构造回文

描述

给定一个字符串s,你可以从中删除一些字符,使得剩下的串是一个回文串。如何删除才能使得回文串最长呢?
输出需要删除的字符个数。
输入描述:
输入数据有多组,每组包含一个字符串s,且保证:1<=s.length<=1000.
输出描述:
对于每组数据,输出一个整数,代表最少需要删除的字符个数。

解法

这道题就是动态规划求最大子集的变形,将一个字符串正序和倒序来一次就行了,但是不知道为什么我的函数在题目上的编辑器里不能够通过。。。
var _lcs = function(str) {
    var table = [];
    for (var i = 0; i < str.length + 1; i++) {
        table[i] = [];
        for (var j = 0; j < str.length + 1; j++) {
            table[i][j] = 0;
        }
    }
    for (var a = 1; a < str.length + 1; a++) {
      for (var b = 1; b < str.length + 1; b++) {
        if (str[a] === str[str.length + 1 - b]) {
          table[a][b] = table[a - 1][b - 1] + 1;
        } else if (table[a - 1][b] >= table[a][b]) {
          table[a][b] = Math.max(table[a - 1][b], table[a][b - 1]);
        }
      }
    }
    return table[str.length][str.length];
};

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文