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

衡水网站建厦门关键词排名优化

衡水网站建,厦门关键词排名优化,新疆住房和城乡建设部网站官网,网站内容设计上的特色Day 67 题目描述 思路 初次思路:此时还不了解什么是前缀树,尝试自己实现一下 由于我们需要快速定位前缀和字符串,于是我想到了使用hashset实现,tes用于存放字符串,prefixs存放前缀,获取前缀通过使用subst…

Day 67

题目描述

在这里插入图片描述

思路

初次思路:此时还不了解什么是前缀树,尝试自己实现一下
由于我们需要快速定位前缀和字符串,于是我想到了使用hashset实现,tes用于存放字符串,prefixs存放前缀,获取前缀通过使用substring进行拆分。

class Trie {Set<String>tes;Set<String>prefixs;public Trie() {tes=new HashSet<String>();prefixs=new HashSet<String>();num=new ArrayList<String>();}public void insert(String word) {if(tes.contains(word)){return;}else{tes.add(word);for(int i=0;i<=word.length();i++){String a=word.substring(0,i);prefixs.add(a);}}}public boolean search(String word) {return tes.contains(word);}public boolean startsWith(String prefix) {return prefixs.contains(prefix);}
}/*** Your Trie object will be instantiated and called as such:* Trie obj = new Trie();* obj.insert(word);* boolean param_2 = obj.search(word);* boolean param_3 = obj.startsWith(prefix);*/

学习前缀树后
前缀树的作用在于快速检索字符串的前缀,插入一个字符串,即为从根一次插入孩子节点,将字符串最后一个字符对应的节点标记结束节点,再插入另外一个相同前缀但最后n个字符不一样的字符串,那么在相同前缀的部分,不需要插入新的节点,直到第一个不同的字符,添加一个新的子节点。
这样做的好处,我们如果要获取两个字符串的前缀,只需要从根节点向下遍历,比较两个字符串,只要到某个节点出现了分支,则这个节点之前的节点就是两个字符的公共前缀。同时节约了存储空间
做法如下:

class Trie {public Trie[]child;//孩子节点,可能插入的是26个英文字母中的一个public boolean isend;//判断是否为一个字符串的结束 区分前缀和字符串public Trie() {child=new Trie[26];isend=false;}public void insert(String word) {Trie node=this;//根节点for(int i=0;i<word.length();i++){char a=word.charAt(i);int index=a-'a';//转化为序号if(node.child[index]==null){node.child[index]=new Trie();//创建为新孩子}node=node.child[index];//移动到下一个孩子}node.isend=true;//将结束标志置为true}public boolean search(String word) {Trie node=searchPrefix(word);if(node!=null&&node.isend){return true;}return false;}public boolean startsWith(String prefix) {Trie node=searchPrefix(prefix);if(node!=null){return true;}return false;}public Trie searchPrefix(String prefix){Trie node=this;for(int i=0;i<prefix.length();i++){char a=prefix.charAt(i);int index=a-'a';if(node.child[index]==null){//还没遍历完前缀就结束了 说明找不到return null;}node=node.child[index];}return node;}
}/*** Your Trie object will be instantiated and called as such:* Trie obj = new Trie();* obj.insert(word);* boolean param_2 = obj.search(word);* boolean param_3 = obj.startsWith(prefix);*/
http://www.dtcms.com/wzjs/355745.html

相关文章:

  • 做网站哪些公司好小学生摘抄新闻
  • 网站网络推广方法智能网站排名优化
  • 广州城市职业学院门户网站seo每日一帖
  • 免费的app软件下载网站网站推广找哪家公司好
  • 响水做网站找哪家好360广告联盟平台
  • 网站 架构设计快速排名怎么做
  • 建设网站租服务器编写网页的软件
  • 清理网站数据库重庆森林壁纸
  • 个体工商户注册网站湘潭网站设计外包公司
  • 计算机网站建设 是什么万能搜索网站
  • 建筑行业网站建设小学培训机构
  • 北京养老网站开发网页设计与制作个人网站模板
  • 什么网站做h5没有广告19
  • 做网站的教程视频关键词推广方法
  • 聊城做手机网站怎么制作属于自己的网址
  • 网站循环滚动图片z怎么做站长号
  • 企业门户网站建设与发展趋势详情页设计
  • 常州网站建设推广seo的理解
  • 安阳做网站电话厦门网站搜索引擎优化
  • 凡科网做音乐网站企业seo自助建站系统
  • 网站首页幻灯片不显示外贸建站推广哪家好
  • 西宁网站建设开发公司广州seo网络推广员
  • 长春网站制作招聘信息深圳网络推广有几种方法
  • 网页网站开发工具株洲seo优化推荐
  • 现在做跨境电商还能赚钱吗网站优化排名
  • 包装盒在线设计网站淘宝关键词top排行榜
  • 电商网站制作教程外链工具
  • 优质校建设专题网站营销渠道方案
  • 厦门手机网站制作推广竞价的公司有哪些
  • 亚马逊美国站黑五网一时间已公布搜索广告优化