【发布时间】:2019-03-03 00:35:49
【问题描述】:
我正在尝试解决 LeetCode 上的this problem,内容如下:
按照the most upvoted Java solution,我想出了以下记忆解决方案:
import functools
class Solution:
def longestPalindromeSubseq(self, s):
return longest_palindromic_subsequence(s)
@functools.lru_cache(maxsize=None)
def longest_palindromic_subsequence(s):
if not s:
return 0
if len(s) == 1:
return 1
if s[0] == s[-1]:
return 2 + longest_palindromic_subsequence(s[1:-1])
return max(
longest_palindromic_subsequence(s[0:-1]),
longest_palindromic_subsequence(s[1:]))
问题是输入字符串出现了很多重复字符,超出了时间限制:
据我从引用的讨论中了解到,没有functools.lru_cache,该算法的时间复杂度为 O(2^N),因为字符串长度每减少一个字符,就会进行两次递归调用。
但是,讨论指出记忆的解决方案是 O(N^2),不应超过时间限制。然而,我并没有真正看到记忆化如何降低时间复杂度,而且这里似乎并非如此。
让我更困惑的是,如果解决方案包含许多重复的字符,它实际上应该在 O(N) 时间内运行,因为每次第一个和最后一个字符相同时,只进行一次递归调用。
谁能向我解释为什么这个测试失败了?
【问题讨论】:
标签: python algorithm time-complexity memoization