【每日一题】771. 宝石与石头

【每日一题】771. 宝石与石头

771. 宝石与石头

题目描述

给你一个字符串 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 中的所有字符都是 唯一的

解题思路

思路:使用哈希表记录宝石,遍历石头并依次判断是否在哈希表中并累计数量。

class Solution {
public:
    int numJewelsInStones(string jewels, string stones) {
unordered_set<char> uset(jewels.begin(),jewels.end());
        int res=0;
        for(auto stone:stones)
        {
            if(uset.count(stone))
                res++;
        }
    return res;
    }
};

猜你喜欢

转载自blog.csdn.net/qq_43779149/article/details/131904831