#3. 掌握的单词个数
掌握的单词个数
有一个字符串数组 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 所有字符串中都仅包含小写英文字母、英文问号
解题思路
1、统计字符出现次数:首先,统计给定字符串 chars 中每个字符(包括通配符 "?")出现的次数。我们可以使用一个长度为 26 的整数数组来存储每个小写字母的出现次数,同时记录通配符的数量。 2、遍历单词数组:对于给定的单词数组 words,逐个检查每个单词是否可以由 chars 中的字符拼写而成。 3、检查单词可否拼写:对于每个单词,遍历其每个字符,并检查在 chars 中是否有足够的相应字符或者通配符来拼写该单词:
- 如果 chars 中有足够的相应字符,则将该字符计数减一。
- 如果没有足够的相应字符,但有通配符,则将通配符数量减一。
- 如果既没有足够的相应字符,也没有通配符,则无法拼写该单词,直接返回 false。
4、在遍历完所有单词后,统计能够拼写的单词数量,并返回该数量。