力扣(LeetCode)2351. 第一个出现两次的字母(C++)

阅读: 评论:0

力扣(LeetCode)2351. 第一个出现两次的字母(C++)

力扣(LeetCode)2351. 第一个出现两次的字母(C++)

哈希集合

开哈希集合,遍历字符串,未出现的字母加入哈希集合,如果字母出现过,返回这个字母即可。

class Solution {
public:char repeatedCharacter(string s) {unordered_set<char> S;for(auto &c:s)if(!S.count(c)) S.insert(c);else return c;return 0;}
};
  1. 时间复杂度 : O ( n ) O(n) O(n) , n n n 是字母数量,遍历每个字母一次,时间复杂度 O ( n ) O(n) O(n) 。
  2. 空间复杂度 : O ( ∣ C ∣ ) O(|C|) O(∣C∣) , 字符集的大小 ∣ C ∣ = 26 |C|= 26 ∣C∣=26 ,哈希集合的空间复杂度 O ( ∣ C ∣ ) O(|C|) O(∣C∣) 。
位运算

字符集一共26个字母,整型数有1位符号位、31位数字位,利用数字位,最多可以表示31个不同的字符。数字位是1表示有这一位,0表示没有这一位。一次遍历字符串,利用位运算,将字母对应到数字位。当前位是0,变为1;当前位是1,返回这个字母即可。

提示 : 位运算小技巧i>>j&1——i表示存储位运算的数字,j表示i的第j位。i>>j&1检查i的第j位是不是1

class Solution {
public:char repeatedCharacter(string s) {int ans = 0;for(auto &c:s){if(ans>>c-'a'&1) return c;ans |= 1<<c-'a';}return 0;}
};
  1. 时间复杂度 : O ( n ) O(n) O(n) , n n n 是字母数量,遍历每个字母一次,时间复杂度 O ( n ) O(n) O(n) 。
  2. 空间复杂度 : O ( 1 ) O(1) O(1) , 只使用常量级空间 。
AC

致语
  • 理解思路很重要
  • 读者有问题请留言,清墨看到就会回复的。

本文发布于:2024-01-29 17:42:18,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170652134217172.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:第一个   两次   字母   力扣   LeetCode
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23