dousui6193 2019-01-29 22:47
浏览 571

检查字符串是否包含Go中的切片中包含的子字符串

I have an array of substrings and a slice of strings. I want to check if the string contains any of the substrings in the mySliceOfSubstrings slice.

mySliceOfSubstrings := []string{"hello", "world"}
mySliceOfStringsToCheck := []string{"hello mars", "hey mars"}

Is there a better way of doing it the below way of putting a loop inside a loop?

for _, string := range mySliceOfStringsToCheck {

     for _, substring := range mySliceOfSubstrings {
          result := strings.Contains(string, substring)

     }  

}

What if I wanted to check the string against two different slice of substrings?

  • 写回答

1条回答 默认 最新

  • doudi8829 2019-01-30 14:26
    关注

    Unless the size of data is very large and you're looking for algorithmic improvements over the O(N^2) solution you currently have, your code is fine.

    For very large data you could consider using some more sophisticated data structures. For example, Go has the https://golang.org/pkg/index/suffixarray package that would let you take your slice of strings to check, preprocess it, and then perform substring lookups in logarithmic time.

    评论

报告相同问题?

悬赏问题

  • ¥15 Vue3 大型图片数据拖动排序
  • ¥15 划分vlan后不通了
  • ¥15 GDI处理通道视频时总是带有白色锯齿
  • ¥20 用雷电模拟器安装百达屋apk一直闪退
  • ¥15 算能科技20240506咨询(拒绝大模型回答)
  • ¥15 自适应 AR 模型 参数估计Matlab程序
  • ¥100 角动量包络面如何用MATLAB绘制
  • ¥15 merge函数占用内存过大
  • ¥15 使用EMD去噪处理RML2016数据集时候的原理
  • ¥15 神经网络预测均方误差很小 但是图像上看着差别太大