其他分享
首页 > 其他分享> > 力扣 387. 字符串中的第一个唯一字符

力扣 387. 字符串中的第一个唯一字符

作者:互联网

题目

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

示例

s = “leetcode”
返回 0

s = “loveleetcode”
返回 2

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/first-unique-character-in-a-string
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

想法

用 counter做~

实现

方法1:python

class Solution:
    def firstUniqChar(self, s: str) -> int:
        n=len(s)
        ss=list(s)
        flag='flag'
        counter = collections.Counter()
        for i in ss:
            counter[i]+=1
        for i,v in counter.items():
            if v==1:
                flag=i
                break
        for i in range(n):
            if flag==ss[i]:
                return i
        if flag=='flag':
            return -1

在这里插入图片描述方法2:python。1改进

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

在这里插入图片描述

标签:返回,return,ss,counter,力扣,int,flag,387,字符串
来源: https://blog.csdn.net/qq_42467009/article/details/119109394