哈理工OJ 1309 入侵检测【kmp匹配】【模板记录】

入侵检测
Time Limit: 1000 MS Memory Limit: 32767 K
Total Submit: 491(153 users) Total Accepted: 183(123 users) Rating: Special Judge: No
Description

入侵检测(Intrusion Detection)是对入侵行为的检测。它通过收集和分析网络行为、安全日志、审计数据、其它网络上可以获得的信息以及计算机系统中若干关键点的信息,检查网络或系统中是否存在违反安全策略的行为和被攻击的迹象。入侵检测作为一种积极主动地安全防护技术,提供了对内部攻击、外部攻击和误操作的实时保护,在网络系统受到危害之前拦截和响应入侵。因此被认为是防火墙之后的第二道安全闸门,在不影响网络性能的情况下能对网络进行监测。入侵检测通过执行以下任务来实现:监视、分析用户及系统活动;系统构造和弱点的审计;识别反映已知进攻的活动模式并向相关人士报警;异常行为模式的统计分析;评估重要系统和数据文件的完整性;操作系统的审计跟踪管理,并识别用户违反安全策略的行为。

其中特征检测(Signature-based detection) 又称Misuse detection 假设入侵者活动可以用一种模式来表示,系统的目标是检测主体活动是否符合这些模式。它可以将已有的入侵方法检查出来。

现在给出主体活动和一个入侵者活动,判断改主体活动是否包含该入侵者活动。

Input

每行两个字符串,表示主体活动和入侵者活动,主体活动串不长与200000,入侵者活动串不长于2000

Output

如果主体活动包含入侵活动,输出”yes”,否则输出”no”,并换行。

Sample Input

abcdefg

abcd

abcde

bcdef

Sample Output

yes

no


直接上KMP模板就行咯~

#include<stdio.h>
#include<string.h>
using namespace std;
char a[200005];
char b[2005];
int next[2005];
int lena;
int lenb;
void set_naxt()//子串的next数组
{
    int i=0,j=-1;
    next[0]=-1;
    while(i<lenb)
    {
        if(j==-1||b[i]==b[j])
        {
            i++; j++;
            next[i]=j;
        }
        else
        j=next[j];
    }
}

int kmp()
{
    int i=0,j=0;
    set_naxt();
    while(i<lena)
    {
        if(j==-1||a[i]==b[j])
        {
            i++;j++;
        }
        else
        j=next[j];
        if(j==lenb)
        return 1;
    }
    return 0;
}
int main()
{
    while(~scanf("%s%s",a,b))
    {
        memset(next,0,sizeof(next));
        lena=strlen(a);
        lenb=strlen(b);
        if(kmp()==1)printf("yes\n");
        else printf("no\n");
    }
}







你可能感兴趣的:(哈理工OJ1309)