leetcode 30 串聯所有單詞的子串

2021-10-03 01:17:14 字數 1165 閱讀 9724

給定乙個字串 s 和一些長度相同的單詞 words。找出 s 中恰好可以由 words 中所有單詞串聯形成的子串的起始位置。

注意子串要與 words 中的單詞完全匹配,中間不能有其他字元,但不需要考慮 words 中單詞串聯的順序。

示例 1:

輸入:s = "barfoothefoobarman",

words = ["foo","bar"]

輸出:[0,9]

解釋:從索引 0 和 9 開始的子串分別是 "barfoo" 和 "foobar" 。

輸出的順序不重要, [9,0] 也是有效答案。

示例 2:

輸入:s = "wordgoodgoodgoodbestword",

words = ["word","good","best","word"]

輸出:

from collections import counter

class solution:

def findsubstring(self, s: str, words: list[str]) -> list[int]:

if s == '' or words == :

return

res =

lens = len(s)

lenword = len(words[0])

counter = counter(words)

for i in range(lenword):

left = right = i

tempcounter = counter()

tempnum = 0

while right + lenword <= lens:

w = s[right:right+lenword]

right += lenword

tempcounter[w] += 1

tempnum += 1

while tempcounter[w] > counter[w]:

leftw = s[left:left+lenword]

left += lenword

tempcounter[leftw] -= 1

tempnum -= 1

if tempnum == len(words):

return res

leetcode 30 串聯所有單詞的子串

leetcode題目鏈結 題目要求 找出 由words陣列組成的字串 每乙個元素word等長 在字元轉s中的位置 陣列words生成的字典dic2 遍歷字串,從頭開始判斷長度為lenwords的字串 生成的字典dic1 如果dic1 與 dic2 相同,說明找到 def findsubstring ...

leetcode 30 串聯所有單詞的子串

給定乙個字串 s 和一些長度相同的單詞 words。找出 s 中恰好可以由 words 中所有單詞串聯形成的子串的起始位置。注意子串要與 words 中的單詞完全匹配,中間不能有其他字元,但不需要考慮 words 中單詞串聯的順序。示例 1 輸入 s barfoothefoobarman words...

leetcode 30 串聯所有單詞的子串

題目 給定乙個字串 s 和一些長度相同的單詞 words。找出 s 中恰好可以由 words 中所有單詞串聯形成的子串的起始位置。注意子串要與 words 中的單詞完全匹配,中間不能有其他字元,但不需要考慮 words 中單詞串聯的順序。示例 1 輸入 s barfoothefoobarman wo...