码迷,mamicode.com
首页 > 其他好文 > 详细

LeetCode|387. 字符串中的第一个唯一字符

时间:2019-12-03 01:48:37      阅读:111      评论:0      收藏:0      [点我收藏+]

标签:love   技术   图片   for   pre   range   diff   fuser   top   

技术图片


题目描述

  • 等级: 简单

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

案例:

s = "leetcode"
返回 0.

s = "loveleetcode",
返回 2.

注意事项:您可以假定该字符串只包含小写字母。

思路

对于字符串和Hash表的考察。
首先遍历一遍字符串中字符,用Hash表存储字符与其出现的次数。
再遍历一遍字符串中的字符,当碰到第一个出现次数为1的字符时,返回响应的索引位置。
如果都没有,返回-1。

答案

func firstUniqChar(s string) int {
    count := map[int32]int{}
    for _, v := range s {
        oldCount := count[v]
        count[v] = 1   oldCount
    }
    for k, v := range s {
        if count[v]==1{
            return k
        }
    }
    return -1
}

结果

技术图片


技术图片
)

LeetCode|387. 字符串中的第一个唯一字符

标签:love   技术   图片   for   pre   range   diff   fuser   top   

原文地址:https://www.cnblogs.com/clawhub/p/11974227.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!