leetcode_1961 检查字符串是否为数组前缀

67 阅读1分钟

要求

给你一个字符串 s 和一个字符串数组 words ,请你判断 s 是否为 words 的 前缀字符串 。

字符串 s 要成为 words 的 前缀字符串 ,需要满足:s 可以由 words 中的前 k(k 为 正数 )个字符串按顺序相连得到,且 k 不超过 words.length 。

如果 s 是 words 的 前缀字符串 ,返回 true ;否则,返回 false 。

示例 1:

输入:s = "iloveleetcode", words = ["i","love","leetcode","apples"]
输出:true
解释:
s 可以由 "i""love""leetcode" 相连得到。

示例 2:

输入:s = "iloveleetcode", words = ["apples","i","love","leetcode"]
输出:false
解释:
数组的前缀相连无法得到 s 。

提示:

  • 1 <= words.length <= 100
  • 1 <= words[i].length <= 20
  • 1 <= s.length <= 1000
  • words[i] 和 s 仅由小写英文字母组成

核心代码

class Solution:
    def isPrefixString(self, s: str, words: List[str]) -> bool:
        return True if [''.join(words[0:i+1]) for i in range(len(words))].count(s) == 1 else False

image.png

解题思路:我们使用字符串拼接,因为题中提到了需要按照顺序,所以我们就按照顺序将所有字符串都拼接完成,然后看下s是不是在其中即可。