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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • JBOSS 下载_JbusDriver

    JBOSS 下载_JbusDriver1:JBossApplicationServerDownloadshttp://jbossas.jboss.org/downloads/只下载JBossAS7.1.1.Final ASCertifiedJavaEE6FullProfile 2012-03-09 LGPL [b]Communityparticipationonly[/b]

    2022年10月4日
    3
  • 免费php网站源码_网页代码生成器

    免费php网站源码_网页代码生成器ASP:CODE:[Copytoclipboard]?http://211.13Array.167.71/waptes…/updateuserinfo.jsp”,falseobjXMLHTTP.setRequestHeader”Content-Type”,”application/x-www-form-urlencoded”objXMLHTTP.setRequestHead…

    2022年10月10日
    3
  • declare-styleable使用

    declare-styleable使用declare-styleable是给自定义控件添加自定义属性用的attr中在attrs.xml中设置declare-styleable,name是PersonAttr<?xmlversion=”1.0″encoding=”utf-8″?><resources><declare-styleablename=”PersonAttr”><attrname=”name”format=”reference”/&gt

    2022年7月13日
    15
  • tomcat7下载安装

    tomcat7下载安装进入apache官网下载tomcat7在最左边的找到download下的tomcat7并点击。选择“32-bit/64-bitWindowsServerInstaller”下载.下载完成后,将安装文件移动到本地硬盘D安装tomcat7,双击下载后的文件,进入安装界面,点next,继续IAgree,组件选择使用默认选项,点next,最后如图所示:

    2022年5月12日
    135
  • C++洗牌算法「建议收藏」

    1、使用标准库中的random_shuffle()函数实现很简单,代码如下:int main() {     vectorint> s_stl;     for (int i=0; i    random_shuffle(s_stl.begin(),s_stl.end());     cout “使用C++算法库:”;     for (vectorint>::iterator it=s_st

    2022年4月7日
    84
  • linux查看80端口占用情况_centos如何查看端口是否被占用

    linux查看80端口占用情况_centos如何查看端口是否被占用前言平常使用linux,我们经常需要查看哪个服务占用了哪个端口,接下来就为大家介绍了2种Linux查看端口占用情况可以使用lsof和netstat命令。1.lsof-i:端口号用

    2022年7月29日
    4

发表回复

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

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