Я пытаюсь решить эту проблему на LeetCode, которая гласит:
После наиболееupvoted решение Java , я пришел к следующему запомненному решению:
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), поскольку каждый раз, когда первый и последний символы совпадают, выполняется только один рекурсивный вызов.
Может кто-нибудь объяснить мне, почему этот тест не пройден?