溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python(Java)實例學習教程:寶石與石頭

發布時間:2020-08-07 13:05:10 來源:ITPUB博客 閱讀:214 作者:千鋒Python唐小強 欄目:編程語言

題目:

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

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

示例 1:

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

示例 2:

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

注意:

  • S 和 J 最多含有50個字母。
  • J 中的字符不重復。
Python(Java)實例學習教程:寶石與石頭

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:

class Solution {
 public int numJewelsInStones(String J, String S) {
 Set<Character> set = new HashSet<>();
 for (char c : J.toCharArray())
 set.add(c);
 int count = 0;
 for (char c : S.toCharArray())
 if (set.contains(c)) count++;
 return count;
 }
}

Python:

class Solution:
 def numJewelsInStones(self, J: str, S: str) -> int:
 count = 0
 hash_set = set(J)
 for c in S:
 if c in hash_set:
 count += 1
 return count


更多的學習教程會繼續為大家更新!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女