本题 题目链接

题目描述


我的题解

(方法三应用更广泛;方法一虽有限制,但很好用,此题中该方法效率也最高)

方法一:(适用于范围确定的)

思路分析

  • 该字符串只包含小写字母,即字符种类最多26个
  • 开一个数组yes[26],分别存放字母a-z所出现的次数。
  • 字符c对应的数组下标索引为为:c-97.
  • 我的代码中,为了节约空间,取的是byte类型数组:
    • 当某个字符出现次数<2,该字符对应的数组值+1;
    • 否则(即出现次数>=2,不符合题目要找的),不处理该字符对应的数组值(即不再+1,因为byte类型最大值为127,而题目数据可能出现某个字符出现次数多达50000的情况)。

代码如下

    public char firstUniqChar(String s) {
char[] chars = s.toCharArray();
byte[] yes = new byte[26];
for (char c : chars) {
if (yes[c-97]<2)yes[c-97]++;
}
char res = ' ';
for (char c : chars) {
if (yes[c-97]==1) {
res = c;
break;
}
}
return res;
}

方法二:哈希表

方法二的优化 是参考leetcode大佬的题解。大佬leetcode主页

思路分析

  • 创建一个哈希表:HashMap<Character, Boolean> dic。
  • 遍历字符串s 中的每个字符 c:
    • 若字符c第一次出现,则向dic中添加键值对:dic.put(c, true);
    • 若前面已经出现过,则修改键c的键值对:dic.put(c, false) 【字符c数量大于1,不符合题目要找的】;

代码如下:

    public char firstUniqChar(String s) {
Map<Character, Boolean> dic = new HashMap<>();
char[] chars = s.toCharArray(); for (char c : chars) { // 遍历字符串
dic.put(c, !dic.containsKey(c)); // 若dic中不包含键 c :则向dic中添加键值对 (c, True) ;
// 若包含键 c :则修改键c的键值对为 (c, False)。
}
char res = ' ';
// 再次遍历字符串s,查看哈希表中键 c对应的value值,找出第一个true
for (char c : chars) {
if (dic.get(c)) {
res = c;
break;
}
}
return res;
}

方法三:有序哈希表

方法三 是参考leetcode大佬的题解。大佬leetcode主页

思路分析

  • 在哈希表的基础上,有序哈希表中的键值对是 按照插入顺序排序 的。
  • 故在方法二的基础上, 对于数据量大的题目,方法三效率更高。
  • 方法二中,第二个for循环,遍历的是字符串s;而方法三中第二个for循环只需遍历有序哈希表即可(因哈希表是去重的,故减少了循环的次数,增加了效率)

代码如下

    public char firstUniqChar(String s) {
Map<Character, Boolean> dic = new LinkedHashMap<>();
char[] chars = s.toCharArray(); for (char c : chars) {
dic.put(c, !dic.containsKey(c)); // 若dic中不包含键 c :则向dic中添加键值对 (c, True) ;
// 若包含键 c :则修改键c的键值对为 (c, False)。
} for (Map.Entry<Character, Boolean> entry : dic.entrySet()) {
if (entry.getValue()) return entry.getKey();
}
return ' ';
}

剑指 Offer 50. 第一个只出现一次的字符的更多相关文章

  1. 剑指 Offer 50. 第一个只出现一次的字符 + 哈希表 + 有序哈希表

    剑指 Offer 50. 第一个只出现一次的字符 Offer_50 题目详情 方法一:使用无序哈希表 package com.walegarrett.offer; /** * @Author Wale ...

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

    题目信息 时间: 2019-07-03 题目链接:Leetcode tag:哈希表 难易程度:简单 题目描述: 在字符串 s 中找出第一个只出现一次的字符.如果没有,返回一个单空格. s 只包含小写字 ...

  3. 【力扣】剑指 Offer 50. 第一个只出现一次的字符

    在字符串 s 中找出第一个只出现一次的字符.如果没有,返回一个单空格. s 只包含小写字母. 示例: s = "abaccdeff"返回 "b" s = &qu ...

  4. [剑指offer] 50. 第一个只出现一次的字符 + map,hashmap 及其区别

    class Solution { public: int FirstNotRepeatingChar(string str) { map<char,int>mp; ;i<str.si ...

  5. 【剑指Offer】第一个只出现一次的字符 解题报告(Python)

    [剑指Offer]第一个只出现一次的字符 解题报告(Python) 标签(空格分隔): 剑指Offer 题目地址:https://www.nowcoder.com/ta/coding-intervie ...

  6. Go语言实现:【剑指offer】第一个只出现一次的字符位置

    该题目来源于牛客网<剑指offer>专题. 在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1( ...

  7. 《剑指offer》第一个只出现一次的字符

    本题来自<剑指offer> 反转链表 题目: 思路: C++ Code: Python Code: 总结:

  8. 剑指Offer:第一个只出现一次的字符

    题目:在字符串中找出第一个只出现一次的字符.如输入"abaccdeff",这输出'b' // 第一个只出现一次的字符 #include <stdio.h> char f ...

  9. 剑指OFFER之第一个只出现一次的字符(九度OJ1283)

    题目描述: 在一个字符串(1<=字符串长度<=10000,全部由大写字母组成)中找到第一个只出现一次的字符. 输入: 输入有多组数据每一组输入一个字符串. 输出: 输出第一个只出现一次的字 ...

随机推荐

  1. OutOfMemory相关问题(内存溢出异常OOM)

    OutOfMemory(内存溢出异常OOM) java.lang.OutOfMemoryError :Thrown when the Java Virtual Machine cannot alloc ...

  2. WPF 精准大小的消息气泡生成

    在其他网站发布过,都是这里写的. 全部为Wpf方式,生成的气泡宽度高度较为精确. 适用任意字体以及字号,可设置图像字体.字号.行间距.字间距.阴影.气泡宽度等,在RichtextboxHelper.c ...

  3. 核心知识点:python入门

    目录 一.python入门day1-day24 day01-03 编程语言 day04 变量 day05 垃圾回收机制(GC机制) 1 引用计数 2 标记清除 3 分代回收 day05 程序交互与基本 ...

  4. C++main函数与命令行参数,退出程序

    本文翻译自:https://docs.microsoft.com/en-us/cpp/cpp/main-function-command-line-args?view=vs-2019 (除动态链接库d ...

  5. 机器学习实战基础(二十三):sklearn中的降维算法PCA和SVD(四) PCA与SVD 之 PCA中的SVD

    PCA中的SVD 1 PCA中的SVD哪里来? 细心的小伙伴可能注意到了,svd_solver是奇异值分解器的意思,为什么PCA算法下面会有有关奇异值分解的参数?不是两种算法么?我们之前曾经提到过,P ...

  6. 数据可视化之分析篇(一)使用Power BI进行动态帕累托分析

    https://zhuanlan.zhihu.com/p/57763423 通过简单的点击交互,就能进行动态分析发现见解,才是我们需要的,恰好这也是 PowerBI 所擅长的. 就帕累托分析来说,能从 ...

  7. Cmd重定向

    1.执行单条cmd命令 public static string ExecuteCmd(string command) { Process p = new Process(); p.StartInfo ...

  8. 集训作业 洛谷P1469 找筷子

    这个题的代码真的是短的不得了呢. 有个神奇的东西叫异或,写起来是这个样子的^. 这个东西可以查看2个数的二进制某位是否相同,相同取0,不同取1.虽然我用的不熟,但我可以想出来,如果2个相同的数异或,答 ...

  9. 30个Linux Shell脚本经典案例(上)

    编写Shell过程中注意事项: 开头加解释器:#!/bin/bash 语法缩进,使用四个空格:多加注释说明. 命名建议规则:变量名大写.局部变量小写,函数名小写,名字体现出实际作用. 默认变量是全局的 ...

  10. python学完可以做什么?Python就业方向最全面的解析

    乔布斯说过:“每一个人都应该学习如何编程,因为编程会教会你如何思考.”下一个时代是人机交互的时代,学习编程不是要让你成为程序员,而让你理解这个时代. 点击免费领取:全网最全python学习导图+14张 ...