关于leetcode:Golang力扣LeetBook初级算法字符串字符串中的第一个唯一字符哈希Map

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

链接: 力扣LeetBook—高级算法—字符串—字符串中的第一个惟一字符.

示例 1:

输出:s = “leetcode”
输入:0

示例 2:

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

标签:队列、哈希表、字符串、计数

提醒:你能够假设该字符串只蕴含小写字母。

大多数的人会使用暴力拆解,这里咱们用的是哈希Map,先遍历上来,记录下每个单词呈现的次数,记录在Map中,再遍历一次,把字符串中的第一个惟一字符的索引返回。

次要Go代码如下:

package main

import (
    "fmt"
)

func firstUniqChar(s string) int {
    str := len(s)
    CharMap := make(map[byte]int)
    //map_variable := make(map[key_data_type]value_data_type)
    for i := 0; i < str; i++ {
        CharMap[s[i]]++
        //fmt.Println(CharMap[s[i]])
    }
    for i := 0; i < str; i++ {
        if CharMap[s[i]] == 1 {
            return i
        }
    }
    return -1
}
func main() {
    fmt.Println(firstUniqChar("loveleetcode"))
}

提交截图

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理