【Leetcode】拼写单词(每日一题)

题目链接:拼写单词


题意:给你一份『词汇表』(字符串数组) words 和一张『字母表』(字符串) chars。

假如你可以用 chars 中的『字母』(字符)拼写出 words 中的某个『单词』(字符串),那么我们就认为你掌握了这个单词。

注意:每次拼写时,chars 中的每个字母都只能用一次。

返回词汇表 words 中你掌握的所有单词的 长度之和。

 

题解:暴力。类似hash?用一个数组统计chars的次数,再复制这个数组,每次在words里的word去遍历,出现不相同的就标记。能顺利遍历就记录一下这个word的长度。

 


代码:

 1 class Solution {
 2 public:
 3     int mp[26] = {0};   
 4 
 5     int countCharacters(vector<string>& words, string chars) {
 6         int len = chars.size();
 7         for(int i = 0; i < len; i++){
 8             mp[chars[i] - 'a']++;
 9         }   //统计
10 
11         int ans = 0;
12         int res[26];    //复制表
13         for(int i = 0; i < words.size(); i++){
14             string word = words[i];
15             memcpy(res,mp,sizeof(mp));
16             int flag = 1;
17             for(int j = 0 ; j < word.size(); j++){
18                 if(res[word[j] - 'a'] == 0){    //如果没有这个字母
19                     flag = 0;
20                     break;
21                 }
22                 else    res[word[j] - 'a']--;
23             }
24             if(flag)    ans += word.size();
25         }
26 
27         return ans;
28     }
29 };

 

posted @ 2020-03-17 21:41  甜酒果。  阅读(165)  评论(0编辑  收藏  举报