leetcode 771. 宝石与石头(Jewels and Stones)

题目描述:

给定字符串J 代表石头中宝石的类型,和字符串 S代表你拥有的石头。 S 中每个字符代表了一种你拥有的石头的类型,你想知道你拥有的石头中有多少是宝石。

J 中的字母不重复,JS中的所有字符都是字母。字母区分大小写,因此"a""A"是不同类型的石头。

示例 1:

输入: J = "aA", S = "aAAbbbb"
输出: 3

示例 2:

输入: J = "z", S = "ZZ"
输出: 0

注意:

  • SJ 最多含有50个字母。
  • J 中的字符不重复。

解法:

class Solution {
public:
    int numJewelsInStones(string J, string S) {
        int res = 0;
        vector<bool> flag(128, false);
        for(char ch : J){
            flag[ch] = true;
        }
        for(char ch : S){
            if(flag[ch]){
                res++;
            }
        }
        return res;
    }
};
posted @ 2019-03-29 14:54  zhanzq1  阅读(133)  评论(0)    收藏  举报