Trie implementation

后端 未结 6 1923
醉梦人生
醉梦人生 2020-12-09 05:19

I am attempting to implement a very simple Trie in Java that supports 3 operations. I\'d like it to have an insert method, a has method (ie is a certain word in the trie),

相关标签:
6条回答
  • 2020-12-09 05:29

    This Trie Map implements has (called get in this implementation) and toString

    0 讨论(0)
  • 2020-12-09 05:40

    Your has function should probably look like this:

    if (c[val]!=null && word.length()>1) {
        return c[val].has(word.substring(1)); //<-- Change is on this line
    } else if (c[val].flag==true && word.length()==1) {
        ...etc
    

    You perform the recursive call, but you really need to let that value propagate back out to the original caller.

    0 讨论(0)
  • 2020-12-09 05:41

    Here is simple java implementation without using any other data structure

    import java.util.ArrayList;
    import java.util.List;
    
    class Trie {
    
        private static Node root = new Node(' ', false);
    
        static int getIndex(char x) {
            return ((int) x) - ((int) 'a');
        }
    
        static class Node {
            char data;
            boolean isLeaf;
            Node[] children;
    
            Node(char data, boolean leaf) {
                this.data = data;
                this.isLeaf = leaf;
                this.children = new Node[26];
            }
    
        }
    
        static void insert(String data, Node root) {
            if (data == null || data.length() == 0) {
                return;
            }
            Node child = root.children[getIndex(data.charAt(0))];
            if (child == null) {
                Node node = new Node(data.charAt(0), data.length() == 1);
                root.children[getIndex(data.charAt(0))] = node;
                if (data.length() > 1) {
                    insert(data.substring(1, data.length()), node);
                }
            } else {
                if (data.length() == 1) {
                    child.isLeaf = true;
                } else {
                    insert(data.substring(1, data.length()), child);
                }
            }
        }
    
        static boolean find(String data, Node root) {
            if (data == null || data.length() == 0) {
                return true;
            }
            char x = data.charAt(0);
            //note that first node ie root is just dummy, it just holds important
            Node node = root.children[getIndex(x)];
            if (node == null) {
                return false;
            } else {
                if (data.length() == 1) {
                    return node.isLeaf;
                } else {
                    return find(data.substring(1, data.length()), node);
                }
            }
        }
    
        static boolean delete(String data, Node root) {
            if (data == null || data.length() == 0) {
                return false;
            }
            char x = data.charAt(0);
            //note that first node ie root is just dummy, it just holds important
            Node node = root.children[getIndex(x)];
            if (node == null) {
                return false;
            } else {
                if (data.length() == 1) {
                    node.isLeaf = false;
                    boolean allNull = true;
                    for (Node node1 : node.children) {
                        allNull = allNull && node1 == null;
                    }
                    return allNull;
                } else {
                    boolean delete = delete(data.substring(1, data.length()), node);
                    if (delete) {
                        node.children[getIndex(x)] = null;
                        if(node.isLeaf){
                            return false;
                        }
                        boolean allNull = true;
                        for (Node node1 : node.children) {
                            allNull = allNull && node1 == null;
                        }
                        return allNull;                }
                }
            }
            return false;
        }
    
    
        private static List<String> strings = new ArrayList<>();
    
        private static List<String> getAll() {
            strings = new ArrayList<String>();
            findAllDFS(root, "");
            return strings;
        }
    
        private static void findAllDFS(Node node, String old) {
            if (node != null) {
                if (node.data != ' ') {
                    old = old + node.data;
                }
                if (node.isLeaf) {
                    strings.add(old);
                }
                for (Node node1 : node.children) {
                    findAllDFS(node1, old);
                }
            }
        }
    
        public static void main(String[] args) {
            insert("abc", root);
            insert("xyz", root);
            insert("abcd", root);
            insert("abcde", root);
    
    
            delete("abcd", root);
    
     /*       System.out.println(find("abc", root));
            System.out.println(find("abcd", root));
            System.out.println(find("ab", root));
            System.out.println(find("xyz", root));*/
    
    
            System.out.println(getAll());
        }
    
    
    }
    
    0 讨论(0)
  • 2020-12-09 05:44

    Here is my implementation: -

    public class Tries {
    
    class Node {
        HashMap<Character, Node> children;
        boolean end;
        public Node(boolean b){
            children = new HashMap<Character, Tries.Node>();
            end = false;
        }
    }
    private Node root;
    public Tries(){
        root = new Node(false);
    }
    public static void main(String args[]){
        Tries tr = new Tries();
        tr.add("dog");
        tr.add("doggy");
    
        System.out.println(tr.search("dogg"));
        System.out.println(tr.search("doggy"));
    }
    private boolean search(String word) {
        Node crawl = root;
        int n = word.length();
        for(int i=0;i<n;i++){
            char ch = word.charAt(i);
            if(crawl.children.get(ch) == null){
                return false;
            }
            else {
                crawl = crawl.children.get(ch);
                if(i==n-1 && crawl.end == true){
                    return true;
                }
    
            }
        }
        return false;
    }
    private void add(String word) {
        Node crawl = root;
        int n = word.length();
        for(int i=0;i<n;i++){
            char ch = word.charAt(i);
            if(crawl.children.containsKey(ch)){
                crawl = crawl.children.get(ch);
            }
            else {
                crawl.children.put(ch, new Node(false));
                Node temp = crawl.children.get(ch);
                if(i == n-1){
                    temp.end = true;
                }
                crawl = temp;
                System.out.println(ch + "      " + crawl.end);
    
            }
        }
    }
    
    }
    
    0 讨论(0)
  • 2020-12-09 05:46

    Maybe you can just use "Map c"instead of "TrieNode[] c", that would allow you to use this for all the types of characters uppercase/lowercase and even special characters and even would save you space ( allocating 26 character array at each character level )

    0 讨论(0)
  • 2020-12-09 05:49

    Here my implementation:

    public class Tries {
    private static class Leaf {
        private Leaf(char c) {
            this.c=c;
        }
        char c;
        int counter = 1;
        List<Leaf> leaves = new ArrayList<>(10);
    }
    private Leaf root = new Leaf('0');
    public void add(String word) {
        Leaf current = root;
        Leaf newLeaf = null;
        for (char c : word.toCharArray()) {
            boolean found = false;
            for (Leaf leaf : current.leaves) {
                if (leaf.c == c) {
                    current = leaf;
                    current.counter++;
                    found=true;
                    break;
                }
            }
            if (!found) {
                newLeaf = new Leaf(c);
                current.leaves.add(newLeaf);
                current = newLeaf;
            }
        }
    }
    public int find(String partial) {
        Leaf current = root;
        for (char c : partial.toCharArray()) {
            boolean found = false;
            for (Leaf leaf : current.leaves) {
                if (leaf.c == c) {
                    current=leaf;
                    found=true;
                    break;
                }
            }
            if(!found) return 0;
        }
        return current.counter;
    }
    
    public boolean hasWord(String partial) {
        return find(partial)>0;
        }
    }
    
    0 讨论(0)
提交回复
热议问题