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

济南网站建设制作公司推荐软件开发专业技能怎么写

济南网站建设制作公司推荐,软件开发专业技能怎么写,网站怎么加载图片做logo,南通市建设工程安全监督站网站概念: Trie 是一种能够快速插入和查询字符串的多叉树结构。、 节点的编号各不相同,根节点编号为0,其他节点用来标识路径,还可以标记单词的插入次数,边表示字符。 tire 维护字符串的集合,支持两种操作&…

概念:

Trie 是一种能够快速插入和查询字符串的多叉树结构。、

节点的编号各不相同,根节点编号为0,其他节点用来标识路径,还可以标记单词的插入次数,边表示字符。

tire 维护字符串的集合,支持两种操作:

1. 向集合中插入一个字符串

2. 在集合中查询一个字符串

建字典树

儿子数组 son[p][26] : 存储从节点p沿着j这条边走到的子节点。边为26个小写字母(a~z)对应的映射值0~25,每个节点最多可以有26个分叉。

计数数组 cnt[p] : 存储以节点p结尾的单词的插入次数

节点编号 idx : 用来给节点编号

1. 空 trie 仅有一个根节点,编号为0

2. 从根开始插,枚举字符串的每个字符

     如果有儿子,则p指针走到儿子

     如果没有儿子,则 先创建儿子,p指针再走到儿子

3. 在单词结束点记录插入次数

模板:

int son[N][26], cnt[N], idx;
// 0号点既是根节点,又是空节点
// son[][]存储树中每个节点的子节点
// cnt[]存储以每个节点结尾的单词数量// 插入一个字符串
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;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];
}

例题:(835. Trie字符串统计 - AcWing题库)

题目:

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

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

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

输入格式

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

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

输出格式

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

每个结果占一行。

数据范围

1≤N≤2∗10^4

输入样例:

5
I abc
Q abc
Q ab
I ab
Q ab

输出样例:

1
0
1

代码:

#include<iostream>
#include<algorithm>
#include<cmath>
#include<cstdio>
#include<string>
#include<queue>
#include<cstring>
#include<sstream>
#include<string.h>
#include<vector>const int N = 1e5 + 10;
using namespace std;
typedef pair<int ,int> PII;
int son[N][26],cnt[N],idx;
char str[N];
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;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];
}
int main(){int n;cin >> n;while(n --){char op[2];scanf("%s%s",op,str);if(op[0] == 'I') insert(str);else printf("%d\n",query(str));}return 0;
}

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

相关文章:

  • 做网站找哪家公司最好网站建设的软硬件平台
  • 博罗东莞网站建设企业网站模板观叫湖南岚鸿团队
  • 佛山定制网站建设湖南网站开发 岚鸿
  • 如何快速提升网站权重招聘网页制作工程师
  • 广州建设行业信息网站软件开发公司排行
  • 物流信息网站cms网站弄论坛形式怎么做
  • 网站建设用户调研9免费建网站
  • 确定网站建设的目的如何开通企业邮箱
  • 承接婚庆公司网站建设本地架设wordpress
  • 搜狐最大的门户网站那些行业做网站优化的比较多
  • 网站建设泽宇app界面设计介绍
  • 网站开发人员什么软件可以免费制作图片
  • 新邱建设网站网站建设遇到的问题及对策
  • 做物流的在什么网站找客户呢韩城全员核酸检测
  • 济南网站制作哪家强自创游戏的软件
  • 岳阳网站建设制作wordpress sticky_posts
  • 天津营销网站建设.net域名 可以做公司网站吗
  • 建设专业网站网络网站做动态图片不显示
  • 湖州吴兴建设局网站做版面的网站
  • 网站开发任务单百度文库做网站用什么平台
  • 长春哪里做网站好当当网站建设的目标
  • 凡科做的网站可以在百度搜到吗wordpress文章伪静态
  • 网站首页 seowordpress 插件 语言
  • 重庆模板网站建设怎么样做网站需要考虑哪些问题
  • 网页设计跟网站建设的区别什么播放器能看无线新闻台直播
  • 电竞网站建设方案被称为网站开发神器
  • 网站关键词排名怎么做上去中企动力的网站如何
  • 做网站用别人的源码可以吗重庆seo整站优化外包服务
  • 网站聚合搜索怎么做有没有会计做兼职的网站
  • php做的直播网站wordpress 标签云制作