序列自动机

简介: 序列自动机

这里母串赋值和算长度不要变,固定模板

int nt[100005][26];
char a[100005];
scanf("%s",a+1);
void init() {
  int len=strlen(a+1);
  for(int i=len; i>=1; i--) {
    for(int j=0; j<26; j++) {
      nt[i-1][j]=nt[i][j];
    }
    nt[i-1][a[i]-'a']=i;
  }
}

判断代码

char b[1005];
    scanf("%s",b);
    int len=strlen(b);
    int p=0,f=0;
    for(int i=0; i<len; i++) {
      p=nt[p][b[i]-'a'];
      if(p==0) {
        f=1;
        break;
      }
    }
    if(f) {
      cout<<"不是子序列"<<endl;
    } else {
      cout<<"是子序列"<<endl;
    }

例题

https://nanti.jisuanke.com/t/38232

#include<iostream>
#include<string.h>
using namespace std;
char a[100005];
int nt[100005][26];
void init() {
  int len=strlen(a+1);
  for(int i=len; i>=1; i--) {
    for(int j=0; j<26; j++) {
      nt[i-1][j]=nt[i][j];
    }
    nt[i-1][a[i]-'a']=i;
  }
}
int main() {
  scanf("%s",a+1);
  int t;
  scanf("%d",&t);
  init();
  while(t--) {
    char b[1005];
    scanf("%s",b);
    int len=strlen(b);
    int p=0,f=0;
    for(int i=0; i<len; i++) {
      p=nt[p][b[i]-'a'];
      if(p==0) {
        f=1;
        break;
      }
    }
    if(f) {
      cout<<"不是子序列"<<endl;
    } else {
      cout<<"是子序列"<<endl;
    }
  }
}
目录
相关文章
|
机器学习/深度学习 传感器 算法
大M序列的产生和相关性质附matlab代码
大M序列的产生和相关性质附matlab代码
【信号去噪】基于马氏距离和EDF统计(IEE-TSP)的基于小波的多元信号去噪方法研究(Matlab代码实现)
【信号去噪】基于马氏距离和EDF统计(IEE-TSP)的基于小波的多元信号去噪方法研究(Matlab代码实现)
|
机器学习/深度学习 传感器 编解码
路径规划算法:基向量加权优化的机器人路径规划算法- 附matlab代码
路径规划算法:基向量加权优化的机器人路径规划算法- 附matlab代码
|
编解码 计算机视觉
基于遗传算法的二进制图像重建(Matlab代码实现)
基于遗传算法的二进制图像重建(Matlab代码实现)
104 0
|
算法 数据挖掘
二进制数据的贝叶斯非参数聚类算法(Matlab代码实现)
二进制数据的贝叶斯非参数聚类算法(Matlab代码实现)
|
机器学习/深度学习 传感器 算法
【元胞自动机】基于元胞自动机模拟森林救火问题附matlab代码
【元胞自动机】基于元胞自动机模拟森林救火问题附matlab代码
|
机器学习/深度学习 传感器 并行计算
【元胞自动机】基于元胞自动机实现传染病传播模拟附matlab代码
【元胞自动机】基于元胞自动机实现传染病传播模拟附matlab代码
|
机器学习/深度学习 传感器 算法
【元胞自动机】基于元胞自动机模拟风速影响的森林火灾模型含Matlab代码
【元胞自动机】基于元胞自动机模拟风速影响的森林火灾模型含Matlab代码
|
机器学习/深度学习 传感器 算法
【交通流】基于元胞自动机模拟收费站交通流附matlab代码
【交通流】基于元胞自动机模拟收费站交通流附matlab代码
|
机器学习/深度学习 传感器 算法
【元胞自动机】基于元胞自动机模拟气体交换碰撞附matlab代码
【元胞自动机】基于元胞自动机模拟气体交换碰撞附matlab代码

热门文章

最新文章