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

 杜杜狼2602891895 发布于 2022-11-10 05:18

题目地址

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

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];
};

撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有