LeetCode_387. 字符串中的第一个唯一字符

1|0写在前面

2|0题目

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

 

 示例 1:
 
 输入: s = "leetcode"
 输出: 0
 示例 2:
 
 输入: s = "loveleetcode"
 输出: 2
 示例 3:
 
 输入: s = "aabb"
 输出: -1
 
 提示:
 
 1 <= s.length <= 105
 s 只包含小写字母
 
 来源:力扣(LeetCode)
 链接:https://leetcode.cn/problems/first-unique-character-in-a-string
 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

 

3|0思路1:

 class Solution:
     def firstUniqChar(self, s: str) -> int:
         for index,_ in enumerate(s): #遍历字符串获取索引
             if s.count(_)==1: #如果计数为1
                 return index #则返回
         else:
             return -1  #没找到计数为1的,就返回-1
  • 方法1的解决效果,写的时候就能想到,耗时比较慢,因为每次获取到一个字符都要从头去遍历一遍。

4|0思路2:hash表

  • count的问题可以通过hash表来规避

  • 得到一个字符的时候设置其次数为1,第二次遇到就+1,依次类推,最终去找value为1的,没有就返回-1

 class Solution:
     def firstUniqChar(self, s: str) -> int:
         hash_s = {}
         for _ in s:
             hash_s[_] = hash_s[_]+1 if _ in hash_s else 1
         for k,v in hash_s.items():
             if v==1:
                 return s.index(k)
         else:
             return -1

 

 

5|0思路3:

  • 其实hash表那部分代码就是python的一些标准库

     s = 'hello'
     from collections import Counter
     counter = Counter(s)
     print(dict(counter))  #{'h': 1, 'e': 1, 'l': 2, 'o': 1}  
  • 修改上述代码

     class Solution:
         def firstUniqChar(self, s: str) -> int:
             from collections import Counter
             hash_s = dict(Counter(s))
             for k,v in hash_s.items():
                 if v==1:
                     return s.index(k)
             else:
                 return -1
  •  

__EOF__

本文作者博客已废弃
本文链接https://www.cnblogs.com/wuxianfeng023/p/16566254.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   博客已废弃  阅读(22)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示