ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

每日一题 - 剑指 Offer 50. 第一个只出现一次的字符

2020-07-04 16:01:35  阅读:217  来源: 互联网

标签:字符 遍历 HashMap Offer 50 dic char 字符串


题目信息

  • 时间: 2019-07-03

  • 题目链接:Leetcode

  • tag:哈希表

  • 难易程度:简单

  • 题目描述:

    在字符串 s 中找出第一个只出现一次的字符。如果没有,返回一个单空格。 s 只包含小写字母。

示例:

s = "abaccdeff"
返回 "b"

s = "" 
返回 " "

注意

1. 0 <= s 的长度 <= 50000

解题思路

本题难点

字符串查找第一个只出现一次的字符,性能最优。

具体思路

哈希表

  • 遍历字符串 s:使用哈希表统计 “各字符数量是否 >1 ”。
  • 再遍历字符串 s :在哈希表中找到首个 “数量为 1的字符”,并返回。

注意

代码

class Solution {
    public char firstUniqChar(String s) {
        HashMap<Character, Boolean> dic = new HashMap<>();
        char[] sc = s.toCharArray();
        for(char c : sc)
            dic.put(c, !dic.containsKey(c));
        for(char c : sc)
            if(dic.get(c)) return c;
        return ' ';
    }
}

复杂度分析:

  • 时间复杂度 O(N) :N为字符串 s的长度;需遍历 s 两轮,使用 O(N) ;HashMap 查找的操作复杂度为 O(1);
  • 空间复杂度 O(N) :HashMap 需存储 N 个字符的键值对,使用 O(N)大小的额外空间。

其他优秀解答

解题思路

有序哈希表,在字符串很长时, 效率更高。

代码

class Solution {
    public char firstUniqChar(String s) {
        char[] array = s.toCharArray();
        HashMap<Character,Boolean> map = new LinkedHashMap<>();
      // 遍历字符串 s 中的每个字符 c ;
        for(char c:array){
          //若 dic 中 不包含 键(key) c :则向 dic 中添加键值对 (c, True) ,代表字符 c 的数量为1
          //若 dic 中 包含 键(key) c :则修改键 c 的键值对为 (c, False) ,代表字符 c 的数量 >1 
            map.put(c,!map.containsKey(c));
        }
      // 判断存在时,直接遍历entrySet,而不是遍历原字符串。在`aaaab`时,效率高
        for(Map.Entry<Character,Boolean> entry:map.entrySet()){
            if(entry.getValue()){
                return entry.getKey();
            }
        }
        return ' ';
    }
}

标签:字符,遍历,HashMap,Offer,50,dic,char,字符串
来源: https://www.cnblogs.com/ID-Wangqiang/p/13235163.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有