leetcode 按分隔符拆分字符串

发布于:2024-11-29 ⋅ 阅读:(18) ⋅ 点赞:(0)

2788. 按分隔符拆分字符串

已解答

简单

相关标签

相关企业

提示

给你一个字符串数组 words 和一个字符 separator ,请你按 separator 拆分 words 中的每个字符串。

返回一个由拆分后的新字符串组成的字符串数组,不包括空字符串 。

注意

  • separator 用于决定拆分发生的位置,但它不包含在结果字符串中。
  • 拆分可能形成两个以上的字符串。
  • 结果字符串必须保持初始相同的先后顺序。

示例 1:

输入:words = ["one.two.three","four.five","six"], separator = "."
输出:["one","two","three","four","five","six"]
解释:在本示例中,我们进行下述拆分:

"one.two.three" 拆分为 "one", "two", "three"
"four.five" 拆分为 "four", "five"
"six" 拆分为 "six" 

因此,结果数组为 ["one","two","three","four","five","six"] 。

示例 2:

输入:words = ["$easy$","$problem$"], separator = "$"
输出:["easy","problem"]
解释:在本示例中,我们进行下述拆分:

"$easy$" 拆分为 "easy"(不包括空字符串)
"$problem$" 拆分为 "problem"(不包括空字符串)

因此,结果数组为 ["easy","problem"] 。

示例 3:

输入:words = ["|||"], separator = "|"
输出:[]
解释:在本示例中,"|||" 的拆分结果将只包含一些空字符串,所以我们返回一个空数组 [] 。 

提示:

  • 1 <= words.length <= 100
  • 1 <= words[i].length <= 20
  • words[i] 中的字符要么是小写英文字母,要么就是字符串 ".,|$#@" 中的字符(不包括引号)
  • separator 是字符串 ".,|$#@" 中的某个字符(不包括引号)
class Solution:
    def splitWordsBySeparator(self, words: List[str], separator: str) -> List[str]:
        result = []  # 创建一个空列表,用于存储最终拆分出来的非空字符串

        for word in words:  # 遍历输入的字符串列表words中的每一个字符串
            split_words = word.split(separator)  # 使用split方法按照指定分隔符拆分当前字符串
            # 得到一个拆分后的字符串列表split_words

            for split_word in split_words:  # 遍历拆分后的字符串列表split_words中的每一个字符串
                if split_word:  # 如果拆分出来的字符串不为空字符串
                    result.append(split_word)  # 将非空字符串添加到result列表中

        return result  # 返回最终的结果列表,包含了所有拆分后的非空字符串
  1. 首先定义了一个空列表 result,用于存储最终拆分出来的非空字符串。
  2. 然后遍历输入的字符串数组 words 中的每一个字符串 word
    • 对于每个 word,使用 split 方法按照指定的分隔符 separator 进行拆分,得到一个拆分后的字符串列表 split_words
    • 接着遍历 split_words 中的每一个拆分出来的字符串 split_word
      • 如果 split_word 不为空字符串(即通过 if split_word: 判断),就将其添加到 result 列表中。
  3. 最后,返回 result 列表,这个列表就是按照分隔符拆分所有字符串后得到的不包含空字符串的新字符串数组。
class Solution:
    def splitWordsBySeparator(self, words: List[str], separator: str) -> List[str]:
        return [s for w in words for s in w.split(separator) if s]

这是一个列表推导式,用于实现核心的字符串拆分和筛选逻辑。具体展开分析如下:

  • 外层循环:for w in words,它会遍历输入的字符串列表 words 中的每一个字符串 w
  • 内层循环:for s in w.split(separator),对于每一个字符串 w,使用 w.split(separator) 方法按照指定的分隔符 separator 对其进行拆分,拆分后会得到一个子字符串列表(例如,如果 w 是 "a,b,c",separator 是 ",",那么 w.split(separator) 就会得到 ["a", "b", "c"]),然后内层循环会遍历这个拆分后的子字符串列表中的每一个子字符串 s
  • 条件筛选:if s,这一步是对通过内层循环得到的每一个子字符串 s 进行筛选,只有当 s 不为空字符串时(即拆分出来的子字符串有实际内容),才会将其保留下来。

最终,经过上述的循环和筛选操作,会得到一个满足条件的子字符串列表,这个列表就是该方法最终要返回的结果。

综上所述,整个代码实现了根据给定分隔符拆分输入的一组字符串,并返回拆分后非空子字符串列表的功能。