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

相关内容

热门资讯

透视教学“wepoker底牌透... 透视教学“wepoker底牌透视脚本app”总是真的有挂(辅助挂)详细辅助力荐教程1、下载好辅助软件...
wepoker免费永久脚本!p... wepoker免费永久脚本!pokemmo辅助器脚本下载,wpk有脚本吗(详细辅助解密教程)1、这是...
透视攻略!wepoker辅助透... 透视攻略!wepoker辅助透视软件,有没有人wepoker(详细辅助必胜教程);致您一封信;亲爱w...
透视好牌!aapoker透视脚... 透视好牌!aapoker透视脚本下载,aapoker怎么设置提高好牌几率,高科技教程(切实真的是有挂...
透视透视挂“德普之星app安卓... 透视透视挂“德普之星app安卓版破解版”一贯是有挂(辅助挂)详细辅助详细教程1、这是跨平台的黑科技,...
hhpoker透视脚本下载!w... hhpoker透视脚本下载!wepoker透视脚本是什么,wepoker透视(详细辅助曝光教程)1)...
透视ai代打!wepoker辅... 1、透视ai代打!wepoker辅助器安装包,wepoker私人局俱乐部怎么进(详细辅助2025教程...
透视神器!aapoker辅助器... 透视神器!aapoker辅助器怎么用,aapoker透视脚本,2025新版(一直是有挂)1.aapo...
透视app“德普之星怎么作弊”... 透视app“德普之星怎么作弊”都是存在有挂(辅助挂)详细辅助必备教程1、机器人多个强度级别选择2、发...
hhpoker万能辅助器!德州... 1、hhpoker万能辅助器!德州机器人代打脚本,wpk脚本是什么(详细辅助解说技巧);代表性(透视...