0

0

特里树

王林

王林

发布时间:2024-07-29 09:13:14

|

912人浏览过

|

来源于dev.to

转载

特里树

实现 trie 数据结构

trie数据结构的strider讲解

html5杯子里萤火虫发光动画特效
html5杯子里萤火虫发光动画特效

一款html5杯子里萤火虫发光动画特效

下载
class node{
    node [] node = new node[26];
    boolean flag;
    public node(){

    }
    public boolean containskey(char c){
        return node[c-'a']!=null;
    }
    public void put(char c, node n){
        node[c-'a']  = n;
    }
    public node get(char c){
        return node[c-'a'];
    }
    public void setflag() {
        this.flag = true;
    }
    public boolean getflag(){
        return this.flag;
    }
}

class trie {
    node root;
    public trie() {
        root = new node();
    }
    //will take tc : o(len) of the word
    public void insert(string word) {
        node node  = root;
        for(int i =0;i<word.length();i++){
            if(!node.containskey(word.charat(i))){
                node.put(word.charat(i),new node());
            }
            node = node.get(word.charat(i));
        }
        node.setflag();
    }
    //will take tc : o(len) of the word
    public boolean search(string word) {
        node node = root;
        for(int i =0;i<word.length();i++){
            if(!node.containskey(word.charat(i))){
                return false;
            }
            node = node.get(word.charat(i));
        }
        return node.getflag();
    }
    //will take tc : o(len) of the prefix
    public boolean startswith(string prefix) {
         node node = root;
        for(int i =0;i<pre class="brush:php;toolbar:false;"fix.length();i++){
            if(!node.containskey(prefix.charat(i))){
                return false;
            }
            node = node.get(prefix.charat(i));
        }
        return true;
    }
}

/**
 * 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);
 */

trie数据结构二

奋斗者的解释,以便更好理解

import java.util.* ;
import java.io.*; 

class node {
    node node[] = new node[26];
    int endwith = 0;// will keep track of no. of words ending with this word
    int countprefix=0;// will keep track of no. of words starting with this word
    public node(){

    }
    public boolean containskey(char c){
        return node[c-'a']!=null;
    }
    public void put(char c, node n){
        node[c-'a'] = n;
    }
    public node get(char c){
        return node[c-'a'];
    }
    public void incrementcountprefix() {
        ++this.countprefix;
    }
    public void decrementcountprefix(){
        --this.countprefix;
    }
    public void incrementendwith(){
        ++this.endwith;
    }
    public void deleteendwith(){
        --this.endwith;
    }
    public int getcountprefix(){
        return this.countprefix;
    }
    public int getendwith(){
        return this.endwith;
    }


}
public class trie {
    node root;
    public trie() {
        // write your code here.
        root = new node();
    }

    public void insert(string word) {
        node node = root;
        for(int i =0;i<word.length();i++){
            if(!node.containskey(word.charat(i))){
                node.put(word.charat(i),new node());
            }
            node = node.get(word.charat(i));
            node.incrementcountprefix();
        }
        node.incrementendwith();
    }

    public int countwordsequalto(string word) {
        // write your code here. 
        node node = root;
        for(int i=0;i<word.length();i++){
            if(node.containskey(word.charat(i))){
                node  = node.get(word.charat(i));
            }
            else return 0;

        }
        return node.getendwith();//this will tell how many strings are 
        //ending with given word

    }



    public int countwordsstartingwith(string word) { 
        node node = root;
        for(int i=0;i<word.length();i++){
            if(node.containskey(word.charat(i))){
                node  = node.get(word.charat(i));
            }
            else return 0;

        }
        return  node.getcountprefix(); // it will tell how many strings are starting 
        //with given word;
    }

    public void erase(string word) {
         node node = root;
        for(int i =0;i<word.length();i++){
            if(node.containskey(word.charat(i))){
                node = node.get(word.charat(i));
                node.decrementcountprefix();
            }
            else return;


        }
        node.deleteendwith();
    }

}

完整字符串

// tc : o(n*l)

import java.util.* ;
import java.io.*; 

class node{
    node[] node = new node[26];
    boolean flag;
    public node(){}
    public void put(char c , node n){
        node[c-'a'] = n;
    }
    public boolean containskey(char c){
        return node[c-'a']!=null;
    }
    public node get(char c){
        return node[c-'a'];
    }
    public void setend(){
        this.flag = true;
    }
    public boolean isend(){
        return this.flag;
    }
}

class trie{
    node root;
    public trie(){
        root = new node();
    }
    public boolean checkifprefixpresent(string s){
      node node = root;
      boolean flag= true;
      for(int i = 0;i<s.length();i++){
          char c = s.charat(i);
          if(!node.containskey(c)){
              return false;
          }
          node = node.get(c);
          flag = flag && node.isend(); // this will check if the substring is also a string from the list of strings
          //if(flag == false) return false; // this line will also work here because if any substring is not present as a string in the trie , then 
          // this string s won't be a complete string, and we can return false here only
      }
      return flag;
  }
  public void insert(string s){
    node node = root;
    for(int i =0;i<s.length();i++){
        char c = s.charat(i);
        if(!node.containskey(c)){
            node.put(c, new node());
        }
        node = node.get(c);
    }
    node.setend(); // setting end of the string as this is the 
          //end of the current string s 
  }
}
class solution {
    static node root;
  public static string completestring(int n, string[] a) {
      trie trie = new trie();
      //storing all the string in the trie data structure
      for(string s : a) trie.insert(s);
      //finding out the comeplete string among all the list of strings
      string completestring = "";
      for(string s : a){
          if(trie.checkifprefixpresent(s)){
              if(completestring.length() < s.length()){
                  completestring = s;
              }
              //lexographical selection : a.compareto(b) =-1 if a < b lexographically 
              else if(completestring.length() == s.length() && s.compareto(completestring) < 0){
                  completestring = s;
              }
          }
      }
      return completestring.equals("") ? "none":completestring;
  }
}

计算不同子串的个数

tc:在
中插入不同的唯一子字符串的 o(n^2) trie数据结构

import java.util.ArrayList;

public class Solution 
{
    Node root;
    static int count;
    public Solution(){
        root = new Node();
    }

    public static int countDistinctSubstrings(String s) 
    {
        count = 0;
        //    Write your code here.
        Solution sol = new Solution();
        for(int i =0;i< s.length();i++){
            String str = "";
            for (int j =i;j< s.length();j++){
                str = str+s.charAt(j);
                sol.insert(str);
            }
        }
        return count+1;
    }
    public void insert(String s){
        Node node = root;
        for(int i =0;i< s.length();i++){
            if(!node.containsKey(s.charAt(i))){
                node.put(s.charAt(i),new Node());
                count++;
            }
            node = node.get(s.charAt(i));
        }
        node.setFlag();
    }
}
class Node {
    Node node[] = new Node[26];
    boolean flag;
    public Node(){

    }
    public boolean containsKey(char c){
        return node[c-'a']!=null;
    }
    public Node get(char c){
        return node[c-'a'];
    }
    public void put(char c, Node n){
        node[c-'a'] = n;
    }
    public void setFlag(){
        this.flag = true;
    }
    public boolean getFlag(){
        return this.flag;
    }
}

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

718

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

219

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1561

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

647

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1148

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

1122

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

188

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

111

2025.08.07

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

1

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号