字典树数组实现「建议收藏」

字典树数组实现「建议收藏」字典树是一种很实用也相对好理解的数据

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

   

字典树又称单词查找树,Trie树,是一种树形结构。典型应用是用于统计,排序和保存大量的字符串(但不仅限于字符串),所以经常被搜索引擎系统用于文本词频统计。它的优点是:利用字符串的公共前缀来减少查询时间,最大限度地减少无谓的字符串比较。

之前在网上找的都是些用指针实现的,代码看起来很难懂,今天学习了一种用数组实现的。学习起来简单易懂


int ch[200010][27];  //节点编号   
int sz;        //字典树节点个数
int val[200010];   //节点的值
void init()
{
    sz=1;
    memset(ch,0,sizeof(ch));
    memset(val,0,sizeof(val));
}
void insert(char *s)
{
    int u=0,c;
    for(int i=0;i<strlen(s);i++)
    {
        c=s[i]-'a';
        if(!ch[u][c])
            ch[u][c]=sz++;
        u=ch[u][c];
        val[u]++;        //!!!
    }
}
int query(char *s)
{
    int u=0,c;
    for(int i=0;i<strlen(s);i++)
    {
        c=s[i]-'a';
        if(!ch[u][c])
            return 0;
        u=ch[u][c];
    }
    return  val[u];
}

说明一下代码中注释的部分,这个语句放在for循环外面有时也是很方便的,当遇到一些特殊的标记,比如1或-1,就代表着字符串的结束,而字符串的中间部分默认都为0。这在有些题中使用是很方便的。


这个数组实现和指针的版本也是有些区别的,数组的版本并不怎么直观,因为在数组中实现的树没有“层”的概念。代替的是节点的“编号”,通过这个编号可以向“下一层”去找节点,也可以通过编号获得字符串的一些其他信息,很多题都需要在结构体或是数组中记录或保存信息,当然这个下标利用的就是“编号”。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/197523.html原文链接:https://javaforall.net

(0)
上一篇 2025年9月2日 上午10:22
下一篇 2025年9月2日 上午11:01


相关推荐

  • grep awk sed_shell grep -v

    grep awk sed_shell grep -vRedflagLinux备份软件测试情况一、测试环境1.备份服务器硬件平台A.    CPU B.    内存C.    硬盘2.备份客户端硬件平台A.    CPU B.    内存C.    硬盘3.软件平台A)     操作系统RedFlagDC4.1RedhatAS4Windows2003EnterpriseServerB)     Domino数据库Domin

    2022年8月20日
    8
  • 微商分销商城购物系统的优势

    微商分销商城购物系统的优势不论买方还是卖方都可以实时查看数据,这些线上的发展模式。微信分销商城是微信公众平台推出的商品营销模式,都是基于微信的一个总店,快速精准的管控微信的各级分店,可控制性强不管是什么类型的营销,传播力度广卖家能够在许多平台上进行推广自己的产品,专为微信而打造微信分销商的功能从前台的服务系统到后台的运营系统,都可以根据自己的需求进行实时查对核实分析,打开微信公众号开通微信分销商城即可,抖音等,若需系统的更好发展。这种多渠道分销可以帮助微商者快速发展下线,数据上有清晰的记录,从招募、运营、分销管理.

    2022年5月17日
    36
  • TGA文件分析

    TGA文件格式概述【OpenGL】游戏编程常用TGA图像格式详解以及加载纹理编程实现分析TGA格式图片使用FlexHEX打开text.tgatest是用像素笔画出的4*4的图像,第一行为白色和三基色,第四行为三补色和黑色,其余两行为白色打开后可以看到结果十分简单:第一个字节是0,表示没有图像的信息字段第二个字节是0,表示没有颜色表第三个字节总是2,表示此类型为格式2接下来五个字节全为0,可以忽略第九第十个字节为0,表示图像X坐标起始位置为0(最左)第十一、十二个字节为0,表示图

    2022年4月7日
    85
  • ffmpeg 入门_python入门笔记

    ffmpeg 入门_python入门笔记写在前面最近在读《FFmpeg从入门到精通》这本书,结合着雷神的博客,学习音视频的知识~在学习的过程中,也记录了一些摘要。因为是边看边记的,所以一些要点在看到后面的时候,需要反过来整理前面的。我用有道云笔记写的markdown没法加图片,所以就先把这部分发了出来。后续会针对内容和排版一步步的优化,如果你被这凌乱的内容辣到了眼睛,请谅解哈哈哈~2019.06.18第一章+第二章知识点(未…

    2022年4月19日
    53
  • KLayout教程(一)画不同的形状

    KLayout教程(一)画不同的形状1 首先创建一个 newlayout2 创建一个 layer 在 edit layer newlayer 即可创建 名字自己命名即可 3 画方形图形 就是 Box 选择你右边的图层 直接可以画 可以在 edit editoroption 编辑画的最小的网格 如下图我选 othergrid 选择 1um 这个可以根据你需要光刻的最小的尺寸定义 然后你还可以用 select 双击你画的图形定义他的位置 3 清除一些你看不见的小点 可能不知道啥时候在哪个地方画了一下 在现在这个 zoom 下看不见 此时就可以用

    2026年3月20日
    2
  • Android 程序包org.apache.http不存在,解决方式

    Android 程序包org.apache.http不存在,解决方式

    2021年10月1日
    60

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号