关键词查找【Aho-Corasick 算法】
创始人
2024-11-21 13:34:41
0

【全程干货】程序员必备算法!AC自动机算法敏感词匹配算法!动画演示讲解,看完轻松掌握,面试官都被你唬住!!_哔哩哔哩_bilibili

著名的多模匹配算法

引入依赖:

    org.ahocorasick    ahocorasick    0.6.3 
public List findKeywordsInText(String text, List keywords) {    Trie trie = Trie.builder()          .addKeywords(keywords)          .build();      long start = System.currentTimeMillis();    Collection emits = trie.parseText(text);    logger.info("trie: " + (System.currentTimeMillis() - start));      List matchedKeywords = new ArrayList<>();    for (Emit emit : emits) {       matchedKeywords.add(emit.getKeyword());    }      return matchedKeywords; }

main demo

public static void main(String[] args) {    String BASE_URL = "https://www.baidu.com/s?wd=";      String text = "abcd";    List wordList = new ArrayList<>();    wordList.add("ab");    wordList.add("bc");    wordList.add("cd");    wordList.add("a");    wordList.add("bcd");    wordList.add("abc");      // 构建 Trie 时忽略大小写  Trie trie = Trie.builder()          .ignoreCase()          .addKeywords(wordList)          .build();      Collection emits = trie.parseText(text);      // 按照关键词长度降序排序  List sortedEmits = new ArrayList<>(emits);    sortedEmits.sort((e1, e2) -> e2.getKeyword().length() - e1.getKeyword().length());      // 移除开始位置在前面词的开始和结束中间的关键词  Set processedKeywords = new HashSet<>();    List filteredEmits = new ArrayList<>();    for (Emit emit : sortedEmits) {       String keyword = emit.getKeyword();       boolean shouldAdd = true;       for (Emit filteredEmit : filteredEmits) {          if (emit.getStart() >= filteredEmit.getStart() && emit.getStart() <= filteredEmit.getEnd()) {             shouldAdd = false;             break;          }       }       if (shouldAdd) {          filteredEmits.add(emit);          processedKeywords.add(keyword);       }    }      // 使用TreeMap来保持emit的start位置顺序  TreeMap firstOccurrences = new TreeMap<>();    for (Emit emit : filteredEmits) {       firstOccurrences.putIfAbsent(emit.getStart(), emit);    }      StringBuilder result = new StringBuilder(text);    int offset = 0;    processedKeywords.clear();    for (Emit emit : firstOccurrences.values()) {       String keyword = emit.getKeyword();       if (!processedKeywords.contains(keyword)) {          int startIndex = emit.getStart() + offset;          int endIndex = emit.getEnd() + 1 + offset;          String link = "" + keyword + "";          result.replace(startIndex, endIndex, link);          offset += link.length() - keyword.length();          processedKeywords.add(keyword);       }    }    System.out.println(result.toString()); }

相关内容

热门资讯

透视软件!哈糖大菠萝万能挂(透... 透视软件!哈糖大菠萝万能挂(透视)底牌透视挂辅助程序(可靠开挂辅助必赢教程)-哔哩哔哩;1、超多福利...
透视工具!wepoker破解工... 透视工具!wepoker破解工具,威信茶馆透视挂,力荐教程(有挂细节)-哔哩哔哩1、起透看视 威信茶...
九分钟了解!微乐家乡麻将挂(辅... 九分钟了解!微乐家乡麻将挂(辅助挂)最初真的是有挂(专业辅助分享教程)-哔哩哔哩;最新版2026是一...
黑科技辅助!wpk发牌可以这离... 黑科技辅助!wpk发牌可以这离谱(智能ai辅助插件安装)软件透明挂黑科技(本来是真的有挂)-哔哩哔哩...
透视实锤!wepoker透视是... 您好:wepoker透视是真的这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多...
透视美元局!wepokerpl... 透视美元局!wepokerplus开挂,武陵游辅助器,线上教程(有挂猫腻)-哔哩哔哩1、下载好武陵游...
黑科技辅助!德州ai辅助外挂(... 黑科技辅助!德州ai辅助外挂(智能ai辅助工具)软件透明挂黑科技(一直有挂)-哔哩哔哩;德州ai辅助...
第九分钟了解!五彩茶馆有挂(辅... 第九分钟了解!五彩茶馆有挂(辅助挂)从前是真的有挂(专业辅助必胜教程)-哔哩哔哩;是一款可以让一直输...
透视挂透视!德州局透视脚本(透... 透视挂透视!德州局透视脚本(透视)底牌透视挂辅助插件(可靠开挂辅助安装教程)-哔哩哔哩相信很多朋友都...
透视挂!wepoker透视方法... 透视挂!wepoker透视方法,微乐春天小程序辅助,必胜教程(有挂解惑)-哔哩哔哩1、完成微乐春天小...