[八我司] 介绍一下Uber tech stack和各个大组的情况

一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
E轮2.5亿美元融资
K12教育独角兽一起作业
北京-诚聘人工智能/教育/大数据岗
坐标湾区
Games Startup
招聘游戏开发工程师
游戏初创公司招聘工程师、UIUX Designer和游戏策划
码农求职神器Triplebyte:
不用海投
内推多家公司面试
把贵司招聘信息放这里
查看: 1130|回复: 0
收起左侧

[Leetcode] 211. Add and Search Word - Data structure design

[复制链接] |试试Instant~ |关注本帖
一回头的温柔 发表于 2016-3-11 17:52:21 | 显示全部楼层 |阅读模式

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?Sign Up 注册获取更多干货

x
求问这一题为什么会超时啊,我就是按implement trie那题的思路建立trie,然后用递归做dfs,代码应该没什么问题,但就是超时了,是建树有什么复杂度低一点的方法吗
public class WordDictionary {
    private TrieNode root= new TrieNode();
    // Adds a word into the data structure.
    public void addWord(String word) {
        HashMap<Character,TrieNode> children=root.children;
        TrieNode next=null;
        for(int i=0;i<=word.length()-1;i++)
        {
            char c=word.charAt(i);
            if(children.containsKey(c))
            {
                next=children.get(c);
                children=next.children;
            }
            else
            {
                next=new TrieNode(c);
                children.put(c,next);
                children=next.children;
            }
            if(i==word.length()-1) next.isLeaf=true;
        }
    }

    // Returns if the word is in the data structure. A word could
    // contain the dot character '.' to represent any one letter.
    public boolean search(String word) {
         return searchhelper(root,word,0);
    }

    public boolean searchhelper(TrieNode root, String word,int index)
    {  
       if(root==null) return false;
       if(word==null||word.length()==0) return true;
       if(index==word.length()&&root.isLeaf) return true;
       if(index>=word.length()) return false;
       HashMap<Character,TrieNode> children=root.children;
       char c=word.charAt(index);
       if(c=='.')
       {
           for(char key:children.keySet())
           {
               if(searchhelper(children.get(key),word,index+1)) return true;
           }
       }
       else
       {
           if(!children.containsKey(c)) return false;
           else
           {
               return searchhelper(children.get(c),word,index+1);
           }
       }
       return false;
    }

    class TrieNode {
        char c;
        HashMap<Character,TrieNode> children=new HashMap<Character,TrieNode>();
        boolean isLeaf=false;

        public TrieNode(char c){
            this.c=c;
    }
     public TrieNode(){

     }
}
}

本版积分规则

提醒:发帖可以选择内容隐藏,部分板块支持匿名发帖。请认真读完以下全部说明:

■隐藏内容方法: [hide=200]你想要隐藏的内容比如面经[/hide]
■意思是:用户积分低于200则看不到被隐藏的内容
■可以自行设置积分值,不建议太高(200以上太多人看不到),也不建议太低(那就没必要隐藏了)
■建议只隐藏关键内容,比如具体的面试题目、涉及隐私的信息,大部分内容没必要隐藏。
■微信/QQ/电子邮件等,为防止将来被骚扰甚至人肉,以论坛私信方式发给对方最安全。
■匿名发帖的板块和方法:http://www.1point3acres.com/bbs/thread-405991-1-1.html

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明

custom counter

GMT+8, 2018-5-25 06:13

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表