LeetCode 1408. 数组中的字符串匹配

博客探讨了LeetCode第1408题——数组中的字符串匹配问题,作者分享了个人思路,指出可能需要两次循环检查字符串是否为其他字符串的子序列,并讨论了时间复杂度和空间复杂度。文章提到KMP算法可以优化时间复杂度,并提到了AC自动机可以实现线性复杂度的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1408. 数组中的字符串匹配

题目:给你一个字符串数组 words ,数组中的每个字符串都可以看作是一个单词。请你按 任意 顺序返回 words 中是其他单词的子字符串的所有单词。
链接 https://leetcode.cn/problems/string-matching-in-an-array/

个人思路
  1. 注意到words[i]与words[j]之间可能是对方的子字符串,所以得使用两次循环,且是类似与放回抽取,但还是忽略了一种情况,那就是words[i]是words[j]的子字符串,同时也是words[k]的子字符串,所以得判断是否已经添加进数组,或者添加进数组以后就break掉第二个循环
class Solution:
    def stringMatching(self, words: List[str]) -> List[str]:
        ans = []
        for word1 in words:
            for word2 in words:
                if word1 != word2 and word1 in word2:
                    ans.append(word1)
                    break
        return ans

时间复杂度:O(n2 × L2),其中 n 是字符串数组的长度,L 是字符串数组中最长字符串的长度。使用KMP 字符串匹配算法可以将时间复杂度优化到O(n2 × T),其中 T 是字符串数组中所有字符串的平均长度。
空间复杂度:O(1)。返回值不计入空间复杂度。如果使用 KMP 字符串匹配算法,那么对应的空间复杂度为 O(T)。

  1. 题解下面的评论:AC自动机可以达到线性复杂度
    可以看看:
    https://leetcode.cn/problems/string-matching-in-an-array/solution/shu-zu-zhong-de-zi-fu-chuan-pi-pei-by-le-rpmt/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值