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

网站专栏怎么做漂亮企业网站建设的好处

网站专栏怎么做漂亮,企业网站建设的好处,小游戏制作开发,网络广告怎么投放作者:指针不指南吗 专栏:算法篇 🐾或许会很慢,但是不可以停下🐾 文章目录1.Trie的基本思想1.1什么是Trie1.2字符串条件1.3如何存储字符串1.4如何查找字符串2.Trie的代码实现2.1怎么用数组建树2.2完整代码1.Trie的基本思…

作者:指针不指南吗
专栏:算法篇

🐾或许会很慢,但是不可以停下🐾

文章目录

  • 1.Trie的基本思想
    • 1.1什么是Trie
    • 1.2字符串条件
    • 1.3如何存储字符串
    • 1.4如何查找字符串
  • 2.Trie的代码实现
    • 2.1怎么用数组建树
    • 2.2完整代码

1.Trie的基本思想

1.1什么是Trie

Trie是用来快速高效查找和查找字符串集合的数据结构。

1.2字符串条件

字符串需要 全是大写,全是小写,0或者1,数字

为什么不能是汉字呢?

因为我们需要把字符串的每个字符映射到每个数组里面去存储,比如全是小写英文的我们需要数组大小为26,那如果是汉字的话,要开个几万的数组,有点麻烦困难,所以字符串都是上述几种情况。

1.3如何存储字符串

具体过程如下(图是借用acwing佬的)

用树来存储字符串;

根节点为0,这里省略根节点;

比如存储字符串abcd

  • 从第一个节点开始,如果第一个节点是a,就往下走,否则就创建一个 a
  • 然后是第二个字符b,找第一个节点的son 如果,sonb,就继续找下找,否则就创建一个
  • 依次往下直到最后一个字符d,最后在字符结束的地方,标记一下

在这里插入图片描述

1.4如何查找字符串

同样利用上图,而且和存储操作很相似

比如查找字符串abcd :

  • 从第一个节点开始,如果是 a ,就通过它的son找下一个字符b,没有a 字符,返回0;
  • 找第二个字符b,通过第一个节点的son 查找,如果是,找下一个,没有返回0;
  • 直到找到最后一个,如果能找到最后一个,并且最后一个上面有字符串结束的标志,返回字符串的个数;

2.Trie的代码实现

先放例题,便于理解

Trie字符串统计

维护一个字符串集合,支持两种操作:

  1. I x 向集合中插入一个字符串 x;
  2. Q x 询问一个字符串在集合中出现了多少次。

共有 N 个操作,所有输入的字符串总长度不超过 105105,字符串仅包含小写英文字母。

输入格式

第一行包含整数 N,表示操作数。

接下来 N 行,每行包含一个操作指令,指令为 I xQ x 中的一种。

输出格式

对于每个询问指令 Q x,都要输出一个整数作为结果,表示 x 在集合中出现的次数。

每个结果占一行。

数据范围

1≤N≤2∗1042*10^42104

输入样例:

5
I abc
Q abc
Q ab
I ab
Q ab

输出样例:

1
0
1

2.1怎么用数组建树

这里比较难懂重点, 我们用一个二维数组去建树 son[N][26]

一维是现在位置是第几个结点(下标),二维是结点和结点之间的关系(谁是谁儿子);

比如son[0][1]=3, [0]表示根节点,[1]表示它有一个儿子b,这个儿子的下标是3;

接着如果有son[3][4]=8 ; 说明根节点的儿子b也有一个儿子c,这个孙子的下标就是8;

这样传递下去,就是一个字符串。

随便给一个结点son[x][y] 并不能看出它在第几层,只能知道,它的儿子是谁。

2.2完整代码

#include<iostream>
using namespace std;const int N=200010;
int son[N][26],idx,cnt[N];
char str[N];void insert(char *str)
{int p=0;  //从根节点开始,找字符for(int i=0;str[i];i++)  //字符串是以'\0'结尾的,可以当作是判断条件{int u=str[i]-'a';  //把26个英文字母映射到 数字 0~25,便于数组存储if(!son[p][u]) son[p][u]=++idx;  //如果该节点为空,就创建一个节点,把字符存进去p=son[p][u];  //找它的儿子,继续}cnt[p]++;  //在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;  //没有想要的节点,说明字符不存在,返回0p=son[p][u];  //下一个节点,继续查找下一个字符}return cnt[p];  //可以按着这个路径走下来,说明有这个字符串,返回字符串的数量
}int main()
{int n;cin>>n;while(n--){char op[2];scanf("%s%s",op,str);if(*op=='I') insert(str);else printf("%d\n",query(str));}return 0;
}

Alt

http://www.yayakq.cn/news/27137/

相关文章:

  • 没技术怎么做网站网店装修网站
  • 关于申请网站建设经费的请示湖南省建设厅易晓林
  • 柏枫谈做网站都需要学什么手写logo设计
  • 找人做网站属于了解些什么呢大连市工程建设信息网
  • wordpress站点链接打不开网址深圳坪山网站制作公司
  • 商城网站的建设怎么做网站内部链接
  • 计算机网站开发项目设计师作品集网站
  • 韩国小清新网站模板免费友链互换
  • 自己做的网站如何上首页怀化网站制作建设
  • 火车票网站建设一站式做网站服务
  • p2p网站建设框架北京海淀建设工程律师推荐
  • wordpress群站特定网站开发
  • 中方元建设工程 网站纺织品做外贸一般在哪个网站上
  • 德阳网站建设平台上海建筑设计院待遇
  • 做网站违反广告法房产信息查询网官网
  • 武隆网站建设哪家好wordpress关闭文章摘要
  • 猪八戒网站做设计兼职流程org域名做网站
  • 学校网站源码html2023年8月新闻热点事件
  • wap网站要花多少钱郑州网站建设喝彩科技
  • 产教融合平台建设网站哪几个做内贸的网站比较好一点
  • 做旅行的网站创建网站首页时通常取文件名为
  • 东莞创意网站设计效果图买空间做网站
  • 网站的建设与颜色搭配建立网站需要多少钱八寇湖南岚鸿团队
  • 青岛wordpress建站安徽安庆地图
  • 无需下载直接进入的网站的代码dw软件免费安装
  • 汕头市建设局网站名词解释seo
  • 延吉最好的网站建设公司企业网站网络营销
  • 我的世界怎么做神器官方网站网站全站开发
  • 模板做网站网站建设费用怎么算
  • 电商网站开发与运营做个页面多少钱