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

自适应网站好还是江西省城乡建设厅网站证件查询

自适应网站好还是,江西省城乡建设厅网站证件查询,网站被挟持怎么办,seo关键词库题目链接:用户登录 题目: 样例: 输入 5 3 aaa aba aabbaa abbbbb cdd aabba abc abab 输出 Y N N 思路: 根据题目意思,要用到 Trie 字典树算法。 Trie 字典树,顾名思义,“字典”&#xff0…

题目链接:用户登录

题目:

样例:

输入
5 3
aaa
aba
aabbaa
abbbbb
cdd
aabba
abc
abab
输出
Y
N
N

思路:

        根据题目意思,要用到 Trie 字典树算法。

Trie 字典树,顾名思义,“字典”,我们查字典的时候,都是找开头的几个字符,来获取我们的整个字符,Trie 字典树,就是通过 前缀字符的一步步扩展。最后查找的时候就是根据我们扩展字典树的步骤来变相查找。字典树,我们也要建立一个 root 跟

比如 :给出以下的几个字符

abcdf

bgre

abfr

baef

最后获得的字典树为:

下面给出 Trie 字典树封装的结构体:


// 定义 Tries 结构体,封装
struct Tries
{// son 用于存储 字符,idx 对应映射整数地址int son[N][26],idx;// 构造 Tries 初始化inline Tries(){memset(son,0,sizeof son);idx = 0;}// 字符串 插入操作inline void Insert(string str){int p = 0;	// 对应root根树的 映射地址int len = str.size();	// 计算 字符串 的长度,方便遍历for(int i = 0;i < len;++i){int u = str[i] - 'a';	// 将 单个字符 转化为 映射整数地址if(!son[p][u]) son[p][u] = ++idx;	// 如果没有当前 地址,扩展映射p = son[p][u];	// 往 存在的结点地址 开始下一次检索}return ;}// 字符串 查找操作 和 插入操作相似,只是不会新建结点inline bool query(string str){int p = 0;	// 对应root根树的 映射地址int len = str.size();	// 计算 字符串 的长度,方便遍历for(int i = 0;i < len;++i){int u = str[i] - 'a';	// 将 单个字符 转化为 映射整数地址if(!son[p][u]) return false;	// 如果没有当前 地址,扩展映射p = son[p][u];	// 往 存在的结点地址 开始下一次检索}return true;}
}tree;

代码详解如下:

#include <iostream>
#include <vector>
#include <queue>
#include <cstring>
#include <algorithm>
#include <unordered_map>
#define endl '\n'
#define int long long
#define YES puts("YES")
#define NO puts("NO")
#define umap unordered_map
#define All(x) x.begin(),x.end()
#pragma GCC optimize(3,"Ofast","inline")
#define IOS std::ios::sync_with_stdio(false),cin.tie(0), cout.tie(0)
using namespace std;
const int N = 2e6 + 10;// 定义 Tries 结构体,封装
struct Tries
{// son 用于存储 字符,idx 对应映射整数地址int son[N][26],idx;// 构造 Tries 初始化inline Tries(){memset(son,0,sizeof son);idx = 0;}// 字符串 插入操作inline void Insert(string str){int p = 0;	// 对应root根树的 映射地址int len = str.size();	// 计算 字符串 的长度,方便遍历for(int i = 0;i < len;++i){int u = str[i] - 'a';	// 将 单个字符 转化为 映射整数地址if(!son[p][u]) son[p][u] = ++idx;	// 如果没有当前 地址,扩展映射p = son[p][u];	// 往 存在的结点地址 开始下一次检索}return ;}// 字符串 查找操作 和 插入操作相似,只是不会新建结点inline bool query(string str){int p = 0;	// 对应root根树的 映射地址int len = str.size();	// 计算 字符串 的长度,方便遍历for(int i = 0;i < len;++i){int u = str[i] - 'a';	// 将 单个字符 转化为 映射整数地址if(!son[p][u]) return false;	// 如果没有当前 地址,扩展映射p = son[p][u];	// 往 存在的结点地址 开始下一次检索}return true;}
}tree;
int n,k;
string s;
inline void solve()
{cin >> n >> k;while(n--){cin >> s;tree.Insert(s);}while(k--){cin >> s;if(tree.query(s)) cout << "Y" << endl;else cout << "N" << endl;}
}signed main()
{
//	freopen("a.txt", "r", stdin);IOS;int _t = 1;
//	cin >> _t;while (_t--){solve();}return 0;
}

最后提交:

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

相关文章:

  • 如何开网站卖东西网站建设哪家技术好
  • 聊城网站建设 推广聊城博达没注册过wordpress有账号
  • 龙游县住房和城乡建设局网站做爰免费网站
  • 中原郑州网站建设公司网站过期未续费会怎样
  • 溧阳市建设网站兰州装修公司
  • 北京网站建设q.479185700強重庆建站费用
  • 旅游网站建设的建议wordpress网站后台要怎么登陆
  • 网站封面制作无极领域网站
  • 友情链接出售平台站长工具seo综合查询
  • 网站建设方案平台选择比较高端的网页
  • 衡水做网站企业广州网站建设中心
  • 手机微信登入网站免费网站站
  • 定州住房和城乡建设局网站网站建设贝尔利
  • 做网站的一些费用俄文网站开发翻译
  • 手机网站视频怎么下载商标logo一键生成器
  • 青岛企业网站推广搜索引擎优化包括哪些方面
  • 免费网站域名cn东营免费网站制作
  • 公司网站建设 公司简介怎么写网站中用特殊字体
  • 哪个网站可以做临时工农业银行总行门户网站建设
  • 网站建设 会议纪要电商网站建设总结
  • 湘潭网站建设 尖端磐石网络网站网站建设的原则有哪些
  • 网站开发费用做账网站策划书格式及范文
  • python做电商网站安康学院的费用
  • 手机记事本做网站wordpress如何使用父导航可点击
  • 沂南建设局网站建设信用卡中心网站首页
  • 网站制作费用需要多少钱海口网红图书馆
  • 网站建设文字wordpress 添加页面模板
  • 开发网站制作网站链接
  • 台州企业网站东莞找工作求职招聘
  • 公司网站在国外打开很慢使用cdn好还是国外租用服务器好miit网站备案