题目:给定一个字符串,找到它的第一个不反复的字符,并返回它的索引。如果不存在,则返回 -1。
链接: 力扣LeetBook—高级算法—字符串—字符串中的第一个惟一字符.
示例 1:
输出:s = "leetcode"
输入:0
示例 2:
输出:s = "loveleetcode"
输入:2
标签:队列、哈希表、字符串、计数
提醒:你能够假设该字符串只蕴含小写字母。
大多数的人会使用暴力拆解,这里咱们用的是哈希Map,先遍历上来,记录下每个单词呈现的次数,记录在Map中,再遍历一次,把字符串中的第一个惟一字符的索引返回。
次要Go代码如下:
package mainimport ( "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"))}
提交截图: