dfs算法java(java算法预测)

packagecom.yangkaile.generator;importlombok.extern.slf4j.Slf4j;importorg.junit.jupiter.api.Test;importjava.util.*;/***@description:DFA算法案例*@className:ApplicationTest*@author:wangdong*@Date:2021/7/2615:56*/@Slf4jpublicclas.

大家好,又见面了,我是你们的朋友全栈君。

package com.yangkaile.generator;

import lombok.extern.slf4j.Slf4j;
import org.junit.jupiter.api.Test;

import java.util.*;

/**
 * @description: DFA算法案例
 * @class Name: ApplicationTest
 * @author: wangdong
 * @Date: 2021/7/26 15:56
 */
@Slf4j
public class ApplicationTest {

    @Test
    public void test1(){
        Set<String> keyWordSet=new HashSet<>();
        keyWordSet.add("五连鞭");
        keyWordSet.add("接化发");
        keyWordSet.add("一鞭");
        keyWordSet.add("二鞭");
        keyWordSet.add("三鞭");
        keyWordSet.add("四鞭");
        keyWordSet.add("五鞭");
        keyWordSet.add("混元形意太极掌门人");
        Map dfa_map=addSensitiveWordToHashMap(keyWordSet);
        Set<String> result=getTriggerOverWord("一鞭后直接五鞭,",dfa_map);
        System.out.println(result);
    }
    /**
     * 构建成DFA算法模型
     * @param keyWordSet
     */
    public Map addSensitiveWordToHashMap (Set<String> keyWordSet) {
        Map sensitiveWordMap = new HashMap(keyWordSet.size());     //初始化关键词容器,减少扩容操作
        String key = null;
        Map nowMap = null;
        Map<String, String> newWorMap = null;
        //迭代keyWordSet
        Iterator<String> iterator = keyWordSet.iterator();
        while (iterator.hasNext()) {
            key = iterator.next();    //关键字
            nowMap = sensitiveWordMap;
            for (int i = 0; i < key.length(); i++) {
                char keyChar = key.charAt(i);       //转换成char型
                Object wordMap = nowMap.get(keyChar);       //获取

                if (wordMap != null) {        //如果存在该key,直接赋值
                    nowMap = (Map) wordMap;
                } else {     //不存在则,则构建一个map,同时将isEnd设置为0,因为他不是最后一个
                    newWorMap = new HashMap<String, String>();
                    newWorMap.put("isEnd", "0");     //不是最后一个
                    nowMap.put(keyChar, newWorMap);
                    nowMap = newWorMap;
                }

                if (i == key.length() - 1) {
                    nowMap.put("isEnd", "1");    //最后一个
                }
            }
        }
        return sensitiveWordMap;
    }

    /**
     * 判断从start后的词是否是关键词 -->基于DFA模型判断
     * @param content
     * @param start
     * @return
     */
    public int getOverWordLength(Map keyWordSet,String content,int start,int matchType){
        boolean flag = false;
        int length = 0;
        char word = 0;
        Map nowMap = keyWordSet;
        for (int i = start ; i < content.length() ; i++ ){
            word = content.charAt(i);
            nowMap = (Map) nowMap.get(word);
            if(nowMap == null){
                break;
            }else {
                length++;
                if("1".equals(nowMap.get("isEnd"))){
                    flag = true;
                    if(1 == matchType){
                        break;
                    }
                }
            }
        }
        if (length < 1 || !flag){
            length = 0;
        }
        return length;
    }

    /**
     * 基于DFA模型匹配关键词
     * @param content 待匹配文本
     * @param keyWordSet  关键词
     * @return 返回匹配到的关键词
     */
    public Set<String> getTriggerOverWord(String content,Map keyWordSet){

        Set<String> words = new HashSet<>();

        for (int i = 0 ; i < content.length() ; i++ ){
            int length = getOverWordLength(keyWordSet, content, i,2);
            if(length > 0){
                words.add(content.substring(i,i+length));
                i = i + length - 1;
            }
        }

        return words;
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/128928.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Java 装饰模式 (Decorator)「建议收藏」

    Java 装饰模式 (Decorator)

    2022年2月4日
    42
  • MIPI协议DSI分析[通俗易懂]

    MIPI协议DSI分析[通俗易懂]本文主要从四个方面来介绍MIPIDSI协议       1、MIPI协议简介、DSI简介       2、DSI协议的D-PHY(物理层)简介       3、DSI协议的DSI(传输接口层)简介     4、DSI协议的DCS(DisplayCommandSet)(指令集)简介       MIPI(移动行业处理器接口)是MobileIndustryPro

    2022年5月29日
    62
  • Java序列化和反序列化

    Java序列化和反序列化

    2021年6月7日
    77
  • Pycharm使用anaconda环境 (原环境 base)

    Pycharm使用anaconda环境 (原环境 base)Pycharm 使用 anaconda 环境 原环境 base 注意本教程是针对使用 anaconda 的新手 添加的是 anaconda 自带的 base 环境 首先打开或者新建一个 Python 项目 File gt Settings gt Project gt PythonInterp 然后在右边 PythonInterp 看一下又没有 anaconde 的选项 如果有 就直接选中 然后就可以了 如果没有那就继续看下去 如果没有默认读取 anaconda 的选项 那

    2025年9月19日
    4
  • 用AVX2指令集优化整形数组求和

    用AVX2指令集优化整形数组求和用AVX2指令集优化高精度加法一、AVX2指令集介绍二、代码实现1.普通高精度加法2.AVX2加速高精度加法3.实现细节说明三、性能测试测试环境计时方式测试内容测试命令测试结果四、总结个人推断原因:一、AVX2指令集介绍AVX2是SIMD(单指令多数据流)指令集,支持在一个指令周期内同时对256位内存进行操作。包含乘法,加法,位运算等功能。下附Intel官网使用文档。Intel®IntrinsicsGuide我们本次要用到的指令是__m256i_mm256_add_epi8(__m2

    2022年5月7日
    50
  • vue富文本编辑器插件推荐_vue富文本编辑器的使用

    vue富文本编辑器插件推荐_vue富文本编辑器的使用vue富文本编辑器,插件

    2022年10月14日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号