工作之余发散学习了 AC 自动机,学习用的是 C++版本。毕业多年才搞懂,惭愧,智商捉急。为了加深理解。用 Go 语言撸了一个 goAcAutoMachine 库。当做总结
Go 实现多模式字符串匹配的 AC 自动机
go get "github.com/zheng-ji/goAcAutoMachine"
package main import ( "fmt" "github.com/zheng-ji/goAcAutoMachine" ) func main() { ac := goAcAutoMachine.NewAcAutoMachine() ac.AddPattern("红领巾") ac.AddPattern("祖国") ac.AddPattern("花朵") ac.Build() content := "我是红领巾,祖国未来的花朵" results := ac.Query(content) for _, result := range results { fmt.Println(result) } }
1 meowhuang 2019-03-08 13:21:51 +08:00 要不要来个后缀数组、后缀树? |