LeetCode-387. 字符串中的第一个唯一字符【队列 哈希表 字符串 计数】

2023-12-15 07:12

本文主要是介绍LeetCode-387. 字符串中的第一个唯一字符【队列 哈希表 字符串 计数】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

LeetCode-387. 字符串中的第一个唯一字符【队列 哈希表 字符串 计数】

  • 题目描述:
  • 解题思路一:用一个哈希表记录所有字符出现的次数,用一个列表unique_chars 记录出现一次的字符,然后从头遍历s,判断当前字符是否位于unique_chars中即可得出答案。
  • 解题思路二:使用哈希表存储索引,出现多次变为-1,我们只需要找到哈希表中值不为-1的最小地址即可。
  • 解题思路三:队列,用哈希表记录元素出现的位置,重复出现则标记为-1。注意这里入队的是字典元素(s[i], i)

题目描述:

给定一个字符串 s ,找到 它的第一个不重复的字符,并返回它的索引 。如果不存在,则返回 -1 。

示例 1:
输入: s = “leetcode”
输出: 0

示例 2:
输入: s = “loveleetcode”
输出: 2

示例 3:
输入: s = “aabb”
输出: -1

提示:

1 <= s.length <= 105
s 只包含小写字母

解题思路一:用一个哈希表记录所有字符出现的次数,用一个列表unique_chars 记录出现一次的字符,然后从头遍历s,判断当前字符是否位于unique_chars中即可得出答案。

class Solution:def firstUniqChar(self, s: str) -> int:dic = {}# 记录字符出现次数for c in s:dic[c] = dic[c] + 1 if c in dic else 1# 过滤出现次数不为一的字符unique_chars = [k for k, v in filter(lambda kvp: kvp[1] == 1, dic.items())]# 遍历目标字符串,返回首个出现在unique_chars中的字符的索引for i, c in enumerate(s):if c in unique_chars:return ireturn -1

更简洁的写法

class Solution:def firstUniqChar(self, s: str) -> int:frequency = collections.Counter(s)for i, ch in enumerate(s):if frequency[ch] == 1:return ireturn -1

时间复杂度:O(n)
空间复杂度:O(26)

解题思路二:使用哈希表存储索引,出现多次变为-1,我们只需要找到哈希表中值不为-1的最小地址即可。

class Solution:def firstUniqChar(self, s: str) -> int:position = {}n = len(s)for i, ch in enumerate(s):if ch in position:position[ch] = -1else:position[ch] = ifirst = nfor pos in position.values():if pos != -1 and pos < first:first = posif first == n:first = -1return first

时间复杂度:O(n)
空间复杂度:O(26)

解题思路三:队列,用哈希表记录元素出现的位置,重复出现则标记为-1。注意这里入队的是字典元素(s[i], i)

class Solution:def firstUniqChar(self, s: str) -> int:position = dict()q = collections.deque()n = len(s)for i, ch in enumerate(s):if ch not in position:position[ch] = iq.append((s[i], i))else:position[ch] = -1while q and position[q[0][0]] == -1:q.popleft()return -1 if not q else q[0][1]

时间复杂度:O(n)
空间复杂度:O(26)

这篇关于LeetCode-387. 字符串中的第一个唯一字符【队列 哈希表 字符串 计数】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/495586

相关文章

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

MySQL 获取字符串长度及注意事项

《MySQL获取字符串长度及注意事项》本文通过实例代码给大家介绍MySQL获取字符串长度及注意事项,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 获取字符串长度详解 核心长度函数对比⚠️ 六大关键注意事项1. 字符编码决定字节长度2

Springboot3+将ID转为JSON字符串的详细配置方案

《Springboot3+将ID转为JSON字符串的详细配置方案》:本文主要介绍纯后端实现Long/BigIntegerID转为JSON字符串的详细配置方案,s基于SpringBoot3+和Spr... 目录1. 添加依赖2. 全局 Jackson 配置3. 精准控制(可选)4. OpenAPI (Spri

C#如何去掉文件夹或文件名非法字符

《C#如何去掉文件夹或文件名非法字符》:本文主要介绍C#如何去掉文件夹或文件名非法字符的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#去掉文件夹或文件名非法字符net类库提供了非法字符的数组这里还有个小窍门总结C#去掉文件夹或文件名非法字符实现有输入字

Java中常见队列举例详解(非线程安全)

《Java中常见队列举例详解(非线程安全)》队列用于模拟队列这种数据结构,队列通常是指先进先出的容器,:本文主要介绍Java中常见队列(非线程安全)的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一.队列定义 二.常见接口 三.常见实现类3.1 ArrayDeque3.1.1 实现原理3.1.2

使用Python实现base64字符串与图片互转的详细步骤

《使用Python实现base64字符串与图片互转的详细步骤》要将一个Base64编码的字符串转换为图片文件并保存下来,可以使用Python的base64模块来实现,这一过程包括解码Base64字符串... 目录1. 图片编码为 Base64 字符串2. Base64 字符串解码为图片文件3. 示例使用注意

C++ RabbitMq消息队列组件详解

《C++RabbitMq消息队列组件详解》:本文主要介绍C++RabbitMq消息队列组件的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. RabbitMq介绍2. 安装RabbitMQ3. 安装 RabbitMQ 的 C++客户端库4. A

golang float和科学计数法转字符串的实现方式

《golangfloat和科学计数法转字符串的实现方式》:本文主要介绍golangfloat和科学计数法转字符串的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望... 目录golang float和科学计数法转字符串需要对float转字符串做处理总结golang float

Python如何判断字符串中是否包含特殊字符并替换

《Python如何判断字符串中是否包含特殊字符并替换》这篇文章主要为大家详细介绍了如何使用Python实现判断字符串中是否包含特殊字符并使用空字符串替换掉,文中的示例代码讲解详细,感兴趣的小伙伴可以了... 目录python判断字符串中是否包含特殊字符方法一:使用正则表达式方法二:手动检查特定字符Pytho

golang实现延迟队列(delay queue)的两种实现

《golang实现延迟队列(delayqueue)的两种实现》本文主要介绍了golang实现延迟队列(delayqueue)的两种实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录1 延迟队列:邮件提醒、订单自动取消2 实现2.1 simplChina编程e简单版:go自带的time