Python(Java)实例学习教程:宝石与石头
题目:
给定字符串J 代表石头中宝石的类型,和字符串 S代表你拥有的石头。 S 中每个字符代表了一种你拥有的石头的类型,你想知道你拥有的石头中有多少是宝石。
J 中的字母不重复,J 和 S中的所有字符都是字母。字母区分大小写,因此"a"和"A"是不同类型的石头。
示例 1:
输入:J="aA",S="aAAbbbb"输出:3
示例 2:
输入:J="z",S="ZZ"输出:0
注意:
S 和 J 最多含有50个字母。J 中的字符不重复。Note:
S and J will consist of letters and have length at most 50.The characters in J are distinct.解题思路:
J 改为 Set 集合, 遍历 S 即可(因为 Set 查找复杂度为常数)
Java:
classSolution{publicintnumJewelsInStones(StringJ,StringS){Set<Character>set=newHashSet<>();for(charc:J.toCharArray())set.add(c);intcount=0;for(charc:S.toCharArray())if(set.contains(c))count++;returncount;}}
Python:
classSolution:defnumJewelsInStones(self,J:str,S:str)->int:count=0hash_set=set(J)forcinS:ifcinhash_set:count+=1returncount
更多的学习教程会继续为大家更新!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。