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

leetcode 困难题 745.Prefix and Suffix Search 前缀和后缀搜索

Problem: 745. Prefix and Suffix Search 前缀和后缀搜索

解题过程

ASCII内,"{"刚好在"z"后面,所以算是特殊字符,按照提示拼起来,然后放入到字典树当中去,并且在{后面的前缀需要求出最大的索引

查询的话直接在字典树上面找就可以,若是空则-1,最后返回最大的索引

Code

class trie { public: bool isend = false; int index = -1; trie* arr[27] = {nullptr}; }; class WordFilter { public: trie* root, *ptr; WordFilter(vector<string>& words) { root = new trie; string tp; for( int i = 0; i < words.size(); i++ ) { ptr = root; tp = "-" + words[i] + "{" + words[i]; while(true) { ptr = root; tp = tp.substr(1, tp.size() - 1); bool pre = false; for(int j = 0; j < tp.size(); j++) { if(ptr->arr[tp[j]-'a'] == nullptr) { ptr->arr[tp[j]-'a'] = new trie; } ptr = ptr->arr[tp[j]-'a']; if(pre) { ptr->index = max(ptr->index, i); } if(tp[j]=='{') pre = true; } if(tp[0]=='{') break; } } } int f(string pref, string suff) { string combine = suff + "{" + pref; ptr = root; for(int i = 0; i < combine.size(); i++) { if(ptr->arr[combine[i]-'a']==nullptr) { return -1; } ptr = ptr->arr[combine[i]-'a']; } return ptr->index; } }; /** * Your WordFilter object will be instantiated and called as such: * WordFilter* obj = new WordFilter(words); * int param_1 = obj->f(pref,suff); */
http://www.jsqmd.com/news/89103/

相关文章:

  • EtherCAT 逐帧报文解析:配置SM/FMMU
  • 列车售票|基于springboot 列车售票系统(源码+数据库+文档)
  • 如何使用SendMessageW或PostMessageW发送换行?
  • 拒绝“面条代码”!Flutter 校园项目的“三层架构”实战
  • 2025.12 北京集训 数学专题
  • 力扣1965-丢失信息的雇员
  • 提示词工程技巧-要 “角色化”,而非 “观点化” 学习
  • Anthropic文章-打造高性能智能体 学习笔记
  • 英语_阅读_Happiness_待读
  • 英语_阅读_Arrest Report Sheet_待读
  • AI在测试中的应用:现状与未来
  • 张量并行 (Tensor Parallelism, TP) 深度解析
  • ‌面试技巧:拿下测试岗位的秘诀
  • Linux修改网络配置和IP地址
  • 三步走截取长图
  • JavaWeb企业级开发---JavaScript
  • 网络安全异想天开(不定期更新)
  • 串口通讯的android 封装开箱即用!提供源代码!
  • 测试左移:构建软件质量的早期防线
  • 力扣1264-页面推荐
  • 抖音uid匹配电话
  • Springboot连锁火锅店餐饮管理系统h2dg0(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
  • [SWPUCTF 2018]SimplePHP
  • Flutter 多端落地实战:Web 与桌面应用的性能优化、SEO 与用户体验全攻略
  • 系统启动和DNS
  • Springboot连锁家政保洁管理系统03zmn(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
  • Flutter 测试全栈指南:从单元测试到黄金路径验证的工程化实践
  • 本凡码农引领杭州小程序开发解决方案赋能企业创新与发展
  • FlutterOpenHarmony商城App标签选择组件开发
  • Springboot连锁药店进销存业务系统98i85(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。