题目:
给你一份『词汇表』(字符串数组) words 和一张『字母表』(字符串) chars。
假如你可以用 chars 中的『字母』(字符)拼写出 words 中的某个『单词』(字符串),那么我们就认为你掌握了这个单词。
注意:每次拼写(指拼写词汇表中的一个单词)时,chars 中的每个字母都只能用一次。
返回词汇表 words 中你掌握的所有单词的 长度之和。
示例:
输入:words = ["cat","bt","hat","tree"], chars = "atach"
输出:6
解释:
可以形成字符串 "cat" 和 "hat",所以答案是 3 + 3 = 6。
解题方法:
题目看起来还挺复杂的,仔细想一想就有一些思路了:
- 统计字母表中每个字母出现的次数;
- 统计词汇表中每个字符串字母出现的次数;如果这个字符串中某个字符数量大于字母表中相同字母的数量,那么说明没有掌握;反之掌握,并累加字符串的长度。
代码和结果:
class Solution {
public:
int countCharacters(vector<string>& words, string chars) {
int cnt[256]={0};
for(int i=0;i<chars.size();i++)
{
cnt[chars[i]]++;
}
int cnt1=0;
for(int i=0;i<words.size();i++)
{
int tmp[256]={0};
bool flag=true;
for(int j=0;j<words[i].size();j++)
{
tmp[words[i][j]]++;
}
for(int j=0;j<words[i].size();j++)
{
if(tmp[words[i][j]]>cnt[words[i][j]])
{
flag=false;
break;
}
}
if(flag)
cnt1+=words[i].size();
}
return cnt1;
}
};
运行结果:
原题链接:https://leetcode-cn.com/problems/find-words-that-can-be-formed-by-characters/
网友评论