3291. 形成目标字符串需要的最少字符串数 I

Powered by:NEFU AB-IN

Link

文章目录

  • [3291. 形成目标字符串需要的最少字符串数 I](#3291. 形成目标字符串需要的最少字符串数 I)

3291. 形成目标字符串需要的最少字符串数 I

题意

给你一个字符串数组 words 和一个字符串 target。

如果字符串 x 是 words 中 任意 字符串的前缀,则认为 x 是一个 有效 字符串。

现计划通过 连接 有效字符串形成 target ,请你计算并返回需要连接的 最少 字符串数量。如果无法通过这种方式形成 target,则返回 -1。

思路

  1. Trie + 记忆化搜索
    首先就是把所有的word全部放进trie,然后进行记忆化搜索即可
    从target的初始下标开始,去trie中匹配,如果到j匹配上了,然后就dfs(j + 1),如果匹配不上,直接break
    记录每个状态的能被最少几个前缀组成,每次用之后的dfs的值更新这个值即可

代码

python 复制代码
# 3.8.9 import
import random
from collections import Counter, defaultdict, deque
from datetime import datetime, timedelta
from functools import lru_cache, reduce
from heapq import heapify, heappop, heappush, nlargest, nsmallest
from itertools import combinations, compress, permutations, starmap, tee
from math import ceil, comb, fabs, floor, gcd, hypot, log, perm, sqrt
from string import ascii_lowercase, ascii_uppercase
from sys import exit, setrecursionlimit, stdin
from typing import Any, Callable, Dict, List, Optional, Tuple, TypeVar

# Constants
TYPE = TypeVar('TYPE')
N = int(2e5 + 10)
M = int(20)
INF = int(1e12)
OFFSET = int(100)
MOD = int(1e9 + 7)

# Set recursion limit
setrecursionlimit(int(2e9))


class Arr:
    array = staticmethod(lambda x=0, size=N: [x() if callable(x) else x for _ in range(size)])
    array2d = staticmethod(lambda x=0, rows=N, cols=M: [Arr.array(x, cols) for _ in range(rows)])
    graph = staticmethod(lambda size=N: [[] for _ in range(size)])


class Math:
    max = staticmethod(lambda a, b: a if a > b else b)
    min = staticmethod(lambda a, b: a if a < b else b)


class Std:
    class TrieNode:
        """TrieNode class can quickly process string prefixes, a common feature used in applications like autocomplete and spell checking."""
        _sid_cnt = 0  # sid counter, representing string index starting from 0

        def __init__(self):
            """Initialize children dictionary and cost. The trie tree is a 26-ary tree."""
            self.children_ = {}
            self._sid = -1  # Unique ID for the node, -1 if not assigned

        def add(self, word: str) -> int:
            """Add a word to the trie with the associated cost and return a unique ID."""
            node = self
            for c in word:
                if c not in node.children_:
                    node.children_[c] = Std.TrieNode()
                node = node.children_[c]
            return node._sid

# --------------------------------------------------------------- Division line ------------------------------------------------------------------


class Solution:
    def minValidStrings(self, words: List[str], target: str) -> int:
        n = len(target)
        trie = Std.TrieNode()

        for word in words:
            trie.add(word)

        @lru_cache(None)
        def dfs(i: int) -> int:
            nonlocal trie
            if i == n:
                return 0
            res = INF

            node = trie
            for j in range(i, n):
                c = target[j]
                if c not in node.children_:
                    break
                sub_res = dfs(j + 1)
                res = Math.min(res, sub_res + 1)
                node = node.children_[c]

            return res

        result = dfs(0)
        dfs.cache_clear()
        return result if result != INF else -1
相关推荐
站大爷IP9 分钟前
Python构建MCP服务器:从工具封装到AI集成的全流程实践
python
深盾安全2 小时前
Python 装饰器详解
python
前端小趴菜052 小时前
python - 数据类型转换
python
跟橙姐学代码3 小时前
学Python必须迈过的一道坎:类和对象到底是什么鬼?
前端·python
卡洛斯(编程版3 小时前
(1) 哈希表全思路-20天刷完Leetcode Hot 100计划
python·算法·leetcode
FreakStudio3 小时前
一文速通 Python 并行计算:教程总结
python·pycharm·嵌入式·面向对象·并行计算
群联云防护小杜4 小时前
从一次 DDoS 的“死亡回放”看现代攻击链的进化
开发语言·python·linq
Ice__Cai4 小时前
Flask 入门详解:从零开始构建 Web 应用
后端·python·flask·数据类型
霸敛4 小时前
好家园房产中介网后台管理完整(python+flask+mysql)
开发语言·python·flask
HenryLin4 小时前
SHAP值的核心概念
python