5922. 统计出现过一次的公共字符串
生活随笔
收集整理的這篇文章主要介紹了
5922. 统计出现过一次的公共字符串
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
5922. 統計出現過一次的公共字符串
給你兩個字符串數組?words1?和?words2?,請你返回在兩個字符串數組中 都恰好出現一次?的字符串的數目。
示例 1:輸入:words1 = ["leetcode","is","amazing","as","is"], words2 = ["amazing","leetcode","is"] 輸出:2 解釋: - "leetcode" 在兩個數組中都恰好出現一次,計入答案。 - "amazing" 在兩個數組中都恰好出現一次,計入答案。 - "is" 在兩個數組中都出現過,但在 words1 中出現了 2 次,不計入答案。 - "as" 在 words1 中出現了一次,但是在 words2 中沒有出現過,不計入答案。 所以,有 2 個字符串在兩個數組中都恰好出現了一次。示例 2:輸入:words1 = ["b","bb","bbb"], words2 = ["a","aa","aaa"] 輸出:0 解釋:沒有字符串在兩個數組中都恰好出現一次。示例 3:輸入:words1 = ["a","ab"], words2 = ["a","a","a","ab"] 輸出:1 解釋:唯一在兩個數組中都出現一次的字符串是 "ab" 。提示:
- 1 <= words1.length, words2.length <= 1000
- 1 <= words1[i].length, words2[j].length <= 30
- words1[i] 和?words2[j]?都只包含小寫英文字母。
解題思路
代碼
class Solution { public:int countWords(vector<string>& words1, vector<string>& words2) {map<string,int> m1,m2;for (int i = 0; i < words1.size(); ++i) {m1[words1[i]]++;}for (int i = 0; i < words2.size(); ++i) {m2[words2[i]]++;}int res(0);for(auto item:m1){if (item.second==1&&m2[item.first]==1)res++;}return res;} }; 創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的5922. 统计出现过一次的公共字符串的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 梦到捉兔子是什么征兆
- 下一篇: 5939. 半径为 k 的子数组平均值