1、题目
给你一个字符串 jewels 代表石头中宝石的类型,另有一个字符串 stones 代表你拥有的石头。 stones 中每个字符代表了一种你拥有的石头的类型,你想知道你拥有的石头中有多少是宝石。
字母区分大小写,因此 “a” 和 “A” 是不同类型的石头。
示例 1:
输入:jewels = “aA”, stones = “aAAbbbb”
输出:3
示例 2:
输入:jewels = “z”, stones = “ZZ”
输出:0
提示:
1 <= jewels.length, stones.length <= 50
jewels 和 stones 仅由英文字母组成
jewels 中的所有字符都是 唯一的
2、解
暴力解法
int numJeweIsInStones(string jewels, string stones){
int cnt = 0;
unordered_map<char, int> js;
for(auto s : stones){
for(auto j : jewels){
if(s == j)
cnt++;
}
}
return cnt;
}
进阶版
一个大佬写的,思路清奇,不需要比较。
直接先读取jewels中字符的ASCALL值,并将其对应位置的元素的置为1,其余值均为0,存储在letter中;最后再根据letter和stones中字符的ASCALL值进行累加即可得到答案。
int numJeweIsInStonesA(string jewels, string stones){
int count = 0;
vector<int> letter(256, 0);
for(int i = 0; i < jewels.length(); i++)
letter[jewels.at(i)] = 1;
for(int i = 0; i < stones.length(); i++)
count += letter[stones.at(i)];
return count;
}