当前位置:   article > 正文

leetcode387:字符串中的第一个唯一字符

leetcode387:字符串中的第一个唯一字符

题目链接:387. 字符串中的第一个唯一字符 - 力扣(LeetCode)

  1. class Solution {
  2. public:
  3. int firstUniqChar(string s) {
  4. unordered_map<char, int> mapch;
  5. for(auto c : s)
  6. {
  7. mapch[c]++;
  8. }
  9. for(int i = 0; i < s.size(); i++)
  10. {
  11. if(mapch[s[i]] == 1)
  12. {
  13. return i;
  14. }
  15. }
  16. return -1;
  17. }
  18. };

这个题目看似简单,实际上很考验你对于字符数组的理解,说白了,这个题目中档,一开始我用的是遍历和标记,最后发现不行。换了unordered_map这个方法,这个方法也是映射,也就是遍历一遍给的字符,把单独的字符在char映射到int中增加1,然后在遍历一遍字符,看看哪个是第一个出现且char映射的int数字只有1,这个就是第一个唯一字符。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/718349
推荐阅读
相关标签
  

闽ICP备14008679号