求解牛客网的一道lcs算法题
求解我的答案为什么不能过通过
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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论