2023-07-24 LeetCode每日一题(宝石与石头)

2023-07-24每日一题

一、题目编号

复制代码
771. 宝石与石头

二、题目链接

点击跳转到题目位置

三、题目描述

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

字母区分大小写,因此 "a" 和 "A" 是不同类型的石头。

提示:

  • 1 <= jewels.length, stones.length <= 50
  • jewels 和 stones 仅由英文字母组成
  • jewels 中的所有字符都是 唯一的

示例1:

示例2:

四、解题代码

cpp 复制代码
class Solution {
public:
    int numJewelsInStones(string jewels, string stones) {
        int cnt=0;
        int length1 = jewels.size();
        int length2 = stones.size();
        for(int i = 0; i < length2; ++i){
            for(int j = 0; j < length1; ++j){
                if(jewels[j] == stones[i]){
                    ++cnt;
                    break;
                }
            }
        }
    return cnt;
    }
};
cpp 复制代码
class Solution {
    unordered_map<char, int> hash1;
public:
    int numJewelsInStones(string jewels, string stones) {
        int cnt = 0;
        int m = jewels.size();
        int n = stones.size();
        for(int i = 0; i < m; ++i){
            hash1[jewels[i]] = 1;
        }
        for(int i = 0; i < n; ++i){
            if(hash1[stones[i]] == 1){
                ++cnt;
            }
        }
    return cnt;
    }
};

五、解题思路

(1) 方法1:直接暴力枚举,利用两层循环,判断stones中的元素是否出现在jewels数组中,出现了就宝石数量加1,不出现就不加1。

(2) 方法2:先遍历一遍jewels数组,用哈希表记录哪些是宝石。再遍历一遍stones数组,如果哈希表中有标记就宝石加1,不出现就不加1.

相关推荐
xiaoye-duck1 分钟前
《算法题讲解指南:优选算法-哈希表》--58.存在重复元素I,59.存在重复元素II,60.字母异位词分组
数据结构·c++·哈希算法
hetao17338372 分钟前
2026-03-26 ZYZ28-CSP-XiaoMao Round 2 hetao1733837 的 record
c++·算法
dazzle2 分钟前
机器学习算法原理与实践-入门(九):基于TensorFlow框架的线性回归
算法·机器学习·tensorflow
CyberMuse8 分钟前
408习题集-数据结构101
算法
迷海10 分钟前
力扣原题《有效的数独游戏》,纯手搓,已验证
算法·leetcode·游戏
freshman_y14 分钟前
经典的C语言题型
c语言·开发语言·算法
small_wh1te_coder14 分钟前
拷打字节技术总监: 详解c语言嵌入式多线程编程中的头文件 #总结 上下篇合 #
c语言·开发语言·算法·操作系统·嵌入式
字节高级特工19 分钟前
C++从入门到熟悉:深入剖析const和constexpr
前端·c++·人工智能·后端·算法
Cathy Bryant19 分钟前
聊聊拓扑学
笔记·算法·数学建模·拓扑学·高等数学
Lisssaa19 分钟前
打卡第二十七天
算法