LeetCode 771. 宝石与石头

目录结构

1.题目

2.题解


1.题目

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

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

示例:

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


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

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/jewels-and-stones
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2.题解

遍历每块石头,检查是不是宝石。

代码实现上通过replace()函数将S中出现在J中的字符全部用""替换

public class Solution771 {
    public int numJewelsInStones(String J, String S) {
        int result = 0;
        char[] chars = J.toCharArray();
        for (char c : chars) {
            result += S.length() - S.replace(String.valueOf(c), "").length();
        }
        return result;
    }
}
  • 时间复杂度:O(MN)MN分别为J和S的长度。
  • 空间复杂度:O(M)

你可能感兴趣的:(LeetCode)