掌握的单词个数

题目
题目描述
有一个字符串数组 words 和一个字符串 chars。
假如可以用 chars 中的字母拼写出 words 中的某个“单词”(字符串),那么我们就认为你掌握了这个单词。words 的字符仅由 a-z英文小写字母组成,例如“abc”
chars 由 a-z 英文小写字母和“?”组成。其中英文“?”"表示万能字符,能够在拼写时当作任意一个英文字母。例如:“?"可以当作“a”等字母。
注意:每次拼写时,chars 中的每个字母和万能字符都只能使用一次。
输出词汇表 words 中你掌握的所有单词的个数。没有掌握任何单词,则输出0。
输入描述
第一行:输入数组 words 的个数,记作N。
第二行~第N+1行:依次输入数组words的每个字符串元素
第N+2行:输入字符串chars
3
blue
hair
id
bd?lue
输出描述
输出一个整数,表示词汇表 words 中你掌握的单词个数
2
备注
1 ≤ words.length ≤ 100
1 ≤ words[i].length, chars.length ≤ 100
所有字符串中都仅包含小写英文字母、英文问号

def check(cnt_chars, cnt_word, num):
    for k in cnt_word.keys():
        if cnt_chars[k] >= cnt_word[k]:
            continue
        else:
            num -= cnt_word[k] - cnt_chars[k]
            if num < 0:
                return False
    return True
from collections import Counter
n = int(input())
words = list()
for _ in range(n):
    words.append(input())
chars = input()
cnt_chars = Counter(chars)
ans = 0
num = cnt_chars["?"]
for word in words:
    cnt_word = Counter(word)
    ans += int(check(cnt_chars, cnt_word, num))
print(ans)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值