Ac.Wing 142.前缀统计

题解:
问加入的字符串中有多少是当前给出的字符串的前缀子串,那么我们就可以对每一个加入的字符串建立Trie树,然后只需要把最后的End数组改一下意义就可以,因为统计的是前缀数目,那我们就把每一个作为结尾的节点数目记录一下,然后当我们发现这个节点是作为结尾的时候,让ans进行一次累加即可
AC代码:

#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<vector>
#include<map>
#include<stack>
#include<queue>
#include<bitset>
#include<list>
#include<limits.h>
#define ll long long
#define INF 1e12
#define inf -1e12
#define me(a,b) memset(a,b,sizeof(a))
#define PII pair<int,int>
#define ull unsigned long long
#define ios std :: ios :: sync_with_stdio(false)

using namespace std;

const int maxn = 1e6 + 19;

int trie[maxn][26] = {},n,m,tot = 1;
int End[maxn] = {};
char str[maxn];


void insert(char * str)
{
   int len = strlen(str),p = 1;
   for(int k = 0;k < len;k++){
       int ch = str[k] - 'a';
       if(trie[p][ch] == 0) trie[p][ch] = ++tot;
       p = trie[p][ch];
   }
   End[p] ++;
}

int Search(char * str)
{
   int len = strlen(str),p = 1,ans = 0;
   for(int k = 0;k < len;k++){
       p = trie[p][str[k] - 'a'];
       if(End[p]) ans += End[p];
   }
   return ans;
}

int main()
{
   ios;
   cin >> n >> m;
   for(int i = 0;i < n;i++){
       cin >> str;
       insert(str);
   }
   for(int i = 0;i < m;i++){
       cin >> str;
       cout << Search(str) << endl;
   }
   return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CUCKyrie

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值