当前位置: 首页 > article >正文

trie树算法--c语言

文章目录

  • 1.什么是trie树
  • 2.trie树的作用
  • 3.trie树的基本操作实现

1.什么是trie树

trie树,属于一种树,结构大概如下
请添加图片描述

假设我们输入几个字符串,adg,abc,ab,adhe,那么我们可以用这个树进行存储,带星号的表明这个字符串出现过,有相同前缀的那么会在一条路径上,比如adg和adhe,ad都是它们的前缀,所以在一条路径上,当出现不同的时候才会分开,我们通过树的形式将一个个节点连接起来(除了根节点不包含字符,其它每一个节点都包含一个字符)

2.trie树的作用

trie树可以用来检索某一个字符串是否出现过,我们通过查询操作来进行实现。

trie也可以统计某一个字符串出现过几次,也是通过查询操作来实现。

trie也可以进行前缀的统计,比如洛谷的这道题目。请添加图片描述
trie还有许多其它的作用(我在这里就不列举了)。

3.trie树的基本操作实现

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] ++ ;
}

这里son数组我们定义为son[题目的要求][26],这里我们只是表示字母,不包含数字,所以有26个。

这是插入操作,str表示我们要插入的字符串,son则表示我们的trie树,idx则表示节点的个数,cnt数组表示这个字符串出现的次数(相当于做一个记号表示出现过),我们先将i当前指向的字符转换成数字编号,所以为str[i]-‘a’,之后我们进行判断,如果当前节点不存在那么我们就创造一个节点,如果存在的话那么我们就向下遍历,最后让cnt[p]++,表示这个字符串出现过一次。

int query(char *str)
{
int p = 0;
for (int i = 0; str[i]; i ++ )
{
    int u = str[i] - 'a';
    if (!son[p][u]) return 0;
    p = son[p][u];
}
return cnt[p];
}

这是询问操作,返回这个字符串出现过几次,先初始化p为0,之后还是将字符转化成数字编号,之后进行查找,如果son[p][u]为0,那么表示没有这个节点,那么我们直接返回0表示没有找到,如果整个循环结束了那就表明我们找到了,就返回cnt[p]所对应的值就行了。


http://www.kler.cn/a/461844.html

相关文章:

  • CG顶会论文阅读|《科技论文写作》硕士课程报告
  • 音频进阶学习九——离散时间傅里叶变换DTFT
  • 38. 考古学家
  • DC-2 靶场渗透
  • 【Multisim用74ls92和90做六十进制】2022-6-12
  • 【Patroni官方文档】介绍与目录
  • 解决Spring boot集成quartz时service注入失败为null的问题
  • 【目标跟踪】checkpoint文件到底是什么?
  • 网页单机版五子棋小游戏项目练习-初学前端可用于练习~
  • 基于W2605C语音识别合成芯片的智能语音交互闹钟方案-AI对话享受智能生活
  • MySQL DBA需要掌握的 7 个问题
  • 使用 Vue CLI 创建 Vue.js 项目的详细指南
  • 【DevOps】Jenkins部署
  • Java jni调用nnom rnn-denoise 降噪
  • WebRTC的线程事件处理
  • 五、其他核心概念
  • 基于SpringBoot在线竞拍平台系统功能实现三
  • 免费的量化交易股票API有哪些局限性?
  • 人工智能-Python上下文管理器-with
  • Windows系统下Rancher安装全攻略:开启容器管理新征程
  • Oracle Dataguard(主库为 Oracle 11g 单节点)配置详解(2):配置主数据库
  • MATLAB条件判断(if_else_end型)
  • WPS计算机二级•表格初认识
  • 【UE5 C++课程系列笔记】18——蓝图变量自动加载“DefaultEngine.ini”文件变量作为默认值
  • 本地快速推断的语言模型比较:Apple MLX、Llama.cpp与Hugging Face Candle Rust
  • EasyPlayer.js遇到播放RTMP视频时,画面显示异常是什么原因?