关键词查找【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()); }

相关内容

热门资讯

WpK最新黑科技!wpk真的太... WpK最新黑科技!wpk真的太假了(WPK ai辅助)起初存在有挂(2026已更新)(哔哩哔哩)1、...
aapokerai辅助!aap... aapokerai辅助!aapoker系统机制,(aapOKER)一般有挂,技巧教程(有挂细节)-哔...
wepoke智能ai!wepo... wepoke智能ai!wepoke是不是有辅助(WePoKe黑科技)本来存在有挂(有挂实锤)-哔哩哔...
教程攻略"aa po... 教程攻略"aa poker有外挂吗"aapoker有外挂吗(切实是真的有挂)-哔哩哔哩;aa pok...
wepoke辅助插件!wepo... wepoke辅助插件!wepoke辅助插件,(wopoker)一般存在有挂,黑科技挂(有挂方法)-哔...
wpK最新黑科技!wpk用什么... wpK最新黑科技!wpk用什么辅助器(WPK ai辅助)起初有挂(2024已更新)(哔哩哔哩)是一款...
wepoke黑科技!wepok... wepoke黑科技!wepoke挂真的假的(WePoKe黑科技)确实有挂(有挂工具)-哔哩哔哩1、起...
微扑克系统发好牌!微扑克辅助器... 这是一款非常优秀的 ia辅助检测软件,能够让你了解到中牌率当中全部隐藏参数,与同类被系统制裁软件相比...
科普分享"aa po... 科普分享"aa poker有外挂吗"aa扑克发牌机制(原来是真的有挂)-哔哩哔哩1、操作简单,无需注...
wPK最新黑科技!wpk ai... wPK最新黑科技!wpk ai(WPK ai辅助)固有是真的有挂(2020已更新)(哔哩哔哩);是一...