开哈希集合,遍历字符串,未出现的字母加入哈希集合,如果字母出现过,返回这个字母即可。
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;}
};
字符集一共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;}
};
本文发布于:2024-01-29 17:42:18,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170652134217172.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |