当前位置 博文首页 > 文章内容

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

    作者: 栏目:未分类 时间:2020-07-04 16:01:05

    本站于2023年9月4日。收到“大连君*****咨询有限公司”通知
    说我们IIS7站长博客,有一篇博文用了他们的图片。
    要求我们给他们一张图片6000元。要不然法院告我们

    为避免不必要的麻烦,IIS7站长博客,全站内容图片下架、并积极应诉
    博文内容全部不再显示,请需要相关资讯的站长朋友到必应搜索。谢谢!

    另祝:版权碰瓷诈骗团伙,早日弃暗投明。

    相关新闻:借版权之名、行诈骗之实,周某因犯诈骗罪被判处有期徒刑十一年六个月

    叹!百花齐放的时代,渐行渐远!



    题目信息

    • 时间: 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 ' ';
        }
    }