【Leetcode】:242. Valid Anagram问题 in Go语言
u013564276 · · 2146 次点击 · · 开始浏览Given two strings s and t, write a function to determine if t is an anagram of s.
For example,
s = "anagram", t = "nagaram", return true.
s = "rat", t = "car", return false.
Note:
You may assume the string contains only lowercase alphabets.
Follow up:
What if the inputs contain unicode characters? How would you adapt your solution to such case?
这个问题,我的思路是用哈希表来解决,分别对s和t遍历一次,遍历s的时候,用字母当关键字,统计字母出现的次数,第二次遍历的时候,每遍历到一个字母就让这个字母的计数减一,这样就能做判断了
题目中提到了unicode的问题,在go语言中可以轻松处理,在对字符串使用for range语句的时候,提取出来的value不是byte类型而是rune类型的,一个rune就能对应一个unicode码
func isAnagram(s string, t string) bool {
if (len(s) != len(t)) {
return false
}
m := map[string]int{}
for _, v := range s {
key, ok := m[string(v)]
if !ok {
m[string(v)] = 1
} else {
m[string(v)] = key + 1
}
}
for _, v := range t {
key, ok := m[string(v)]
if !ok {
return false
}
if key == 0 {
return false
}
m[string(v)] = key - 1
}
return true
}有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
Given two strings s and t, write a function to determine if t is an anagram of s.
For example,
s = "anagram", t = "nagaram", return true.
s = "rat", t = "car", return false.
Note:
You may assume the string contains only lowercase alphabets.
Follow up:
What if the inputs contain unicode characters? How would you adapt your solution to such case?
这个问题,我的思路是用哈希表来解决,分别对s和t遍历一次,遍历s的时候,用字母当关键字,统计字母出现的次数,第二次遍历的时候,每遍历到一个字母就让这个字母的计数减一,这样就能做判断了
题目中提到了unicode的问题,在go语言中可以轻松处理,在对字符串使用for range语句的时候,提取出来的value不是byte类型而是rune类型的,一个rune就能对应一个unicode码
func isAnagram(s string, t string) bool {
if (len(s) != len(t)) {
return false
}
m := map[string]int{}
for _, v := range s {
key, ok := m[string(v)]
if !ok {
m[string(v)] = 1
} else {
m[string(v)] = key + 1
}
}
for _, v := range t {
key, ok := m[string(v)]
if !ok {
return false
}
if key == 0 {
return false
}
m[string(v)] = key - 1
}
return true
}