快速算法,怎样判断所有 String2 的字母在 String1 里面是否存在

2014-09-21 10:03:38 +08:00
 729334218
4037 次点击
所在节点    问与答
18 条回复
WeberXie
2014-09-21 10:04:30 +08:00
大众点评的测评吧,用简单hash啊,我都做完咯
729334218
2014-09-21 10:07:01 +08:00
麻烦能说一下吗,谢谢啦
andrewhxism
2014-09-21 10:26:28 +08:00
Kmp
Ultratude
2014-09-21 10:29:47 +08:00
看毛片可以。
phuslu
2014-09-21 10:47:52 +08:00
啊,当年我的实习面试题就是这个。
http://ideone.com/pHEEiA
Exin
2014-09-21 10:59:42 +08:00
字母是指a-z?
用两组bool数组,长度26,表示a-z
在String2里存在的字母对应的bool值为true,其余为false
对String1同样的操作
然后对比两组bool

算法不是很好,如果效率太低请轻喷、求指导
wy315700
2014-09-21 11:07:31 +08:00
@Exin 都O(n) 了 效率不低了啊
hit9
2014-09-21 11:09:34 +08:00
Kmp
proudzhu
2014-09-21 11:32:12 +08:00
以前看到的用位做标志的
http://ideone.com/BspbkW
Exin
2014-09-21 11:45:12 +08:00
@wy315700 这样啊……我第一次回答算法方面的问题,比较紧张
xcv58
2014-09-21 11:49:40 +08:00
@wy315700 请教低于 O(n) 的解法。
jokester
2014-09-21 12:36:13 +08:00
怎樣可以低於O(n) ? 把String1和String2都過一遍已經是O(n)了
xuelang
2014-09-21 12:38:47 +08:00
@andrewhxism 不是string2在string1中出现,是string2中的字母是否在string1出现..
lu18887
2014-09-21 13:54:11 +08:00
kmp
yhf
2014-09-21 14:11:37 +08:00
大众点评的题目吧,话说你这样真的好么...

我是开了一个长度26的数组,记录每个字母是否出现过。不过应该还有更好的算法,用位运算什么的,应该可以再减少一点空间,没有细想。
ghostcat
2014-09-21 14:20:53 +08:00
kmp+1
daoluan
2014-09-21 15:16:01 +08:00
kmp o(n)
andrewhxism
2014-09-23 07:26:14 +08:00
@xuelang 哦,看错了,无脑哈希之。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/134762

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX