Leetcode 771: 寶石與石頭

題目描述:

 給定字符串J 代表石頭中寶石的類型,和字符串 S代表你擁有的石頭。 S 中每個字符代表了一種你擁有的石頭的類型,你想知道你擁有的石頭中有多少是寶石。

J 中的字母不重複,J 和 S中的所有字符都是字母。字母區分大小寫,因此"a"和"A"是不同類型的石頭。

示例 1:

輸入: J = "aA", S = "aAAbbbb"
輸出: 3
示例 2:

輸入: J = "z", S = "ZZ"
輸出: 0
注意:

S 和 J 最多含有50個字母。
 J 中的字符不重複。

來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/jewels-and-stones
著作權歸領釦網絡所有。商業轉載請聯繫官方授權,非商業轉載請註明出處。

思路:哈希

/**
 * @param {string} J
 * @param {string} S
 * @return {number}
 */
var numJewelsInStones = function(J, S) {
    let hash = {};
    let res = 0;
    for(let i = 0; i < S.length; i++) {
        hash[S[i]] = hash[S[i]] ? hash[S[i]] + 1 : 1;
    }
    for(let j = 0; j < J.length; j++) {
        if(hash.hasOwnProperty(J[j])) {
            res += hash[J[j]];
        }
    }
    return res;
};

 

發佈了198 篇原創文章 · 獲贊 14 · 訪問量 2萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章