洛谷--前缀统计c语言

题目如下

代码如下

复制代码
#include<stdio.h>
int son[1000010][26]={0};
int cnt[1000010]={0};
char str[1000010]={0}; 
  int idx=0;
void insert(char *str){
int p=0;
for(int i=0;str[i];i++){
    int u=str[i]-'a';
    if(!son[p][u]) son[p][u]=++idx;
    p=son[p][u];
}
cnt[p]++;
}
int query(char *str){
int p=0,sum=0;
for(int i=0;str[i];i++){
    int u=str[i]-'a';
    p=son[p][u];
    if(p==0) return sum;
    if(cnt[p]) sum+=cnt[p];
}
return sum;
}
int main(){
int end;
int m,n;
scanf("%d%d",&n,&m);
for(int i=0;i<n;i++){
    scanf("%s",str);
    insert(str);
}
for(int i=0;i<m;i++){
    scanf("%s",str);
    end=query(str);
    printf("%d\n",end);
}
return 0;
}

这道题目用到的是字典树trie树,这个树的主要操作有两个,一个是插入,一个是访问,这里我重点讲一下访问。

可能会有人问为什么先让p=son[p][u]再去进行判断,而不是先进行sum+=cnt[p],进行完后再进行p=son[p][u],我举个例子。

假设m和n都是1,之后我们先输入abc,再输入abc,根据题目的意思其实就是判断a是不是abc的前缀,根据我们的插入操作将a插入进去,插入结束后p为1,那cnt[3]就加1,这时cnt[3]就为1,这时再回到我们的询问函数上,如果先sum+=cnt[p],那么加完后sum还是0(因为cnt[0]为0),p=0,之后进行p=son[p][u],这时p=1,进行下一轮循环(这时str[i]等于b),继续进行sum+=cnt[p],这时sum还是0,p=1,之后进行p=son[p][u],这时p=2,继续下一轮(这时srt[i]等于c),sum+=cnt[p],sum还是0,p=2,之后进行p=son[p][u],p=3,这时结束循环,因为str[4]为'\0',但是sum还是0,正常来讲sum应该为1,问题就出在我前面那两步的顺序上,如果交换顺序那么当我们插入的字符串和我们要询问的字符串相等的时候,就比如前面那种(都输入abc时)就会出现错误,少加1次。所以我们才要让p=son[p][u]。

前面讲的可能很乱,我再总结一下原因,不管我们输入几个字符,cnt[0]永远是0,因为就算我们一开始只输入一个字符,这时son[p][u]=++idx,这时son[p][u]已经为1了(idx一开始初始化为0),那么我们再让p=son[p][u],那么p这时为1,最后结束循环,cnt[p],也就是cnt[1]++,所以cnt[0]永远是0,那么我们询问操作时,一开始p=0,根本不需要管cnt[0],直接让p=son[p][u]就可以了。

这里我再说一下为什么p==0时直接返回,因为如果p=0了,那么说明我们str数组中的这个字符没有出现在我们树的这条路径上出现过,直接返回就可以了。

(讲的不清不楚的,各位只能将就一下了,抱歉)

相关推荐
hugh_oo几秒前
100 天学会爬虫 · Day 11:如何合理控制爬虫请求频率?让访问行为更像真人
开发语言·爬虫·python
天赐学c语言16 分钟前
12.18 - 有效的括号 && C语言中static的作用
数据结构·c++·算法·leecode
JIngJaneIL17 分钟前
基于java+ vue建筑材料管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
季远迩21 分钟前
LeetCode 热题 100 Python3易懂题解(更新中)
算法·leetcode·哈希算法
半梅芒果干22 分钟前
vue3 新建文件store自动导入
开发语言·前端·javascript
CoovallyAIHub23 分钟前
从“模仿”到“进化”!华科&小米开源MindDrive:在线强化学习重塑「语言-动作」闭环驾驶
深度学习·算法·计算机视觉
Tony Bai23 分钟前
Go 1.26 新特性前瞻:从 Green Tea GC 到语法糖 new(expr),性能与体验的双重进化
开发语言·后端·golang
悟能不能悟34 分钟前
Java 中将 List 中对象的某一列转换为 Set
java·开发语言·list
xie_pin_an35 分钟前
C 语言排序算法全解析:从原理到实战,附性能对比
c语言·算法·排序算法
CoovallyAIHub37 分钟前
SAM 真的开始「分割一切」,从图像到声音,Meta 开源 SAM Audio
深度学习·算法·计算机视觉