【LeetCode】Day52

2047.句子中的有效单词数

句子仅由小写字母('a' 到 'z')、数字('0' 到 '9')、连字符('-')、标点符号('!'、'.' 和 ',')以及空格(' ')组成。每个句子可以根据空格分解成 一个或者多个 token ,这些 token 之间由一个或者多个空格 ' ' 分隔。

如果一个 token 同时满足下述条件,则认为这个 token 是一个有效单词:

仅由小写字母、连字符和/或标点(不含数字)。
至多一个 连字符 '-' 。如果存在,连字符两侧应当都存在小写字母("a-b" 是一个有效单词,但 "-ab" 和 "ab-" 不是有效单词)。
至多一个 标点符号。如果存在,标点符号应当位于 token 的 末尾 。
这里给出几个有效单词的例子:"a-b."、"afad"、"ba-c"、"a!" 和 "!" 。

给你一个字符串 sentence ,请你找出并返回 sentence 中 有效单词的数目 。

解法①:遍历

class Solution:
    def countValidWords(self, sentence: str) -> int:
        #定义判断单词是否有效的函数
        def valid(s):
            #“当前字符”有效标志符(注意理解)
            isValid = False
            for i,cha in enumerate(s):
                #如果当前字符是数字或者是不在末尾位置的标点符号,那么不是合法单词(注意这里不是末尾位置标点符号的判断方式)
                if cha.isdigit() or cha in "!,." and i < len(s)-1 :
                    return False
                #如果当前字符是-,需要判断其位置
                if cha == "-":
                    #isValid在判断-之前是False;如果-位于单词开头或者结尾则单词不合法;如果-两端的字符不是小写字母,则单词不合法
                    #注意这个地方的not,重要!
                    if isValid or i == 0 or i == len(s)-1 or not s[i-1].islower() or not s[i+1].islower():
                        return False
                    #当前字符合法,标志位置为True;如果不止一个-,那么isValid变为True,再进入第14行的判断则返回False
                    #示例:“a-b-” --->这种情况就会返回False
                    isValid = True
            return True
        

        #统计有效单词数,使用字符串的split()方法实现按照空格分割sentence
        return sum(valid(s) for s in sentence.split())

复杂度:

时间复杂度:O(n),其中 n 是句子的长度。切分整个句子,并处理单词需要 O(n)。

空间复杂度:O(1)。只需要常数空间保存变量。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值