宝石与石头
# 宝石与石头 (opens new window)
Category | Difficulty | Likes | Dislikes |
---|---|---|---|
algorithms | Easy (85.22%) | 721 | - |
Companies
给你一个字符串 jewels
代表石头中宝石的类型,另有一个字符串 stones
代表你拥有的石头。 stones
中每个字符代表了一种你拥有的石头的类型,你想知道你拥有的石头中有多少是宝石。
字母区分大小写,因此 "a"
和 "A"
是不同类型的石头。
示例 1:
输入:jewels = "aA", stones = "aAAbbbb"
输出:3
1
2
2
示例 2:
输入:jewels = "z", stones = "ZZ"
输出:0
1
2
2
提示:
1 <= jewels.length, stones.length <= 50
jewels
和stones
仅由英文字母组成jewels
中的所有字符都是 唯一的
Discussion (opens new window) | Solution (opens new window)
/*
* @Author: 仲灏<izhaong@outlook.com>🌶🌶🌶
* @Date: 2022-11-09 11:42:49
* @LastEditTime: 2022-11-09 11:45:45
* @LastEditors: 仲灏<izhaong@outlook.com>🌶🌶🌶
* @Description:
* @FilePath: /leetcode/771.宝石与石头.ts
*/
/*
* @lc app=leetcode.cn id=771 lang=typescript
*
* [771] 宝石与石头
*
* https://leetcode.cn/problems/jewels-and-stones/description/
*
* algorithms
* Easy (85.22%)
* Likes: 721
* Dislikes: 0
* Total Accepted: 174.5K
* Total Submissions: 204.8K
* Testcase Example: '"aA"\n"aAAbbbb"'
*
* 给你一个字符串 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 中的所有字符都是 唯一的
*
*
*/
// @lc code=start
function numJewelsInStones(jewels: string, stones: string): number {
let num = 0
for (let i = 0; i < stones.length; i++) {
const s = stones[i];
if(jewels.indexOf(s) !== -1) {
num ++
}
}
return num
};
function numJewelsInStones1(jewels: string, stones: string): number {
const jewelsSet = new Set(jewels.split(""));
return stones.split("").reduce((prev, val) => {
return prev + jewelsSet.has(val);
}, 0);
}
// @lc code=end
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
上次更新: 2022/11/09, 12:24:33