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

一亩三分地论坛

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

LEETCODE的WORD BREAK,自己写的,麻烦大家看下对不对,顺便问下URN TIME

[复制链接] |试试Instant~ |关注本帖
ryuichist 发表于 2015-5-8 16:14:51 | 显示全部楼层 |阅读模式

2015(4-6月) 码农类General 本科 全职@PoketGem - 网上海投 - Onsite  | Pass | 在职跳槽

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

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

x
如题,自己写了一下,请大家看看写的如何?有没有BUG?我自己跑了几个CASE,没什么问题
第一个方法是暴力法,第二个是一唯DP。顺便问下RUN TIME?. 围观我们@1point 3 acres
暴力法我觉得是2^n,DP的话应该是O(n*m)
来源一亩.三分地论坛.
        public static boolean wordBreak_naive(String s, Set<String> dict) {
                return wordBreakHelper(s, dict, 0);
        }
        //brute force solution, worst case runs at O(2^n)
        public static boolean wordBreakHelper(String s, Set<String> dict, int start_index){       
                if(start_index == s.length()){
                        return true;
                }. Waral 博客有更多文章,
. 一亩-三分-地,独家发布
                for(String word : dict){       
                        int end_index = start_index + word.length();
                        if(end_index > s.length()){
                                continue;
                        }-google 1point3acres
                        if(s.substring(start_index, end_index).equals(word)){
                                return wordBreakHelper(s, dict, end_index);
                        }
                }
                return false;
        }


. 1point3acres
下面的是DP
        public static boolean wordBreak_DP(String s, Set<String> dict){. from: 1point3acres
                boolean[] t = new boolean[s.length()+1];
                t[0] = true; //set first to be true, why? Because we need initial state
                for(int i=0; i<s.length(); i++){

                        if(t == false)                                 //should continue from match position
                                continue;.留学论坛-一亩-三分地
                        for(String word: dict){
                                int endindex = i + word.length();
                                if(endindex > s.length()){        //out of bound, continue
                                        continue;
                                }. 一亩-三分-地,独家发布
                                if(t[endindex]){                //already checked, continue
                                        continue;. Waral 博客有更多文章,
                                }
                                if(s.substring(i, endindex).equals(word)){. 围观我们@1point 3 acres
                                        t[endindex] = true;
                                }
                        }
                }. 牛人云集,一亩三分地
                return t[s.length()];
        }

notturno 发表于 2015-5-8 20:26:14 | 显示全部楼层
看了下DP,应该没什么问题
不过算法上的时间复杂度肯定可以优化,t[endindex]=true这里有可能已经判断到string最后一个字母了,实际上已经可以返回结果不用再跑循环了

如果用dict.contains()来判断,可以做到O(n^2),通常情况还是m远大于n的
回复 支持 反对

使用道具 举报

 楼主| ryuichist 发表于 2015-5-9 02:14:58 | 显示全部楼层
notturno 发表于 2015-5-8 20:26
看了下DP,应该没什么问题
不过算法上的时间复杂度肯定可以优化,t[endindex]=true这里有可能已经判断到st ...

哦,了解,这样的话可以节约一点点

你说的dict.contains是什么意思呢,没看懂
回复 支持 反对

使用道具 举报

notturno 发表于 2015-5-9 02:23:27 | 显示全部楼层
ryuichist 发表于 2015-5-9 02:14
哦,了解,这样的话可以节约一点点.留学论坛-一亩-三分地

你说的dict.contains是什么意思呢,没看懂

就是set class下的函数,用set.contains()来判断substring是否是字典的一个词
回复 支持 反对

使用道具 举报

 楼主| ryuichist 发表于 2015-5-9 02:58:43 | 显示全部楼层
notturno 发表于 2015-5-9 02:23
就是set class下的函数,用set.contains()来判断substring是否是字典的一个词

嗯我知道这个函数 我的意思是 在哪里用这个 感觉要改算法
回复 支持 反对

使用道具 举报

 楼主| ryuichist 发表于 2015-5-9 03:10:56 | 显示全部楼层
notturno 发表于 2015-5-9 02:23
就是set class下的函数,用set.contains()来判断substring是否是字典的一个词

懂你的意思了 你的意思是不遍历dict 然后用另外一个index作为endindex 然后查字
回复 支持 反对

使用道具 举报

rengokantai 发表于 2015-5-10 07:58:18 | 显示全部楼层
第二种解法第五行 t==false?.本文原创自1point3acres论坛
. 留学申请论坛-一亩三分地


补充内容 (2015-5-10 07:59):
哦,看明白了.
论坛应该开发一个贴代码的插件, 否则 方括号i 总是被解析成HTML斜体字, 看起来及其不方便
回复 支持 反对

使用道具 举报

 楼主| ryuichist 发表于 2015-5-11 17:14:00 | 显示全部楼层
rengokantai 发表于 2015-5-10 07:58
第二种解法第五行 t==false?
. Waral 博客有更多文章,
对的,每次贴代码都很痛苦
Mobile Apps Category (English)728x90
回复 支持 反对

使用道具 举报

本版积分规则

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

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

关闭

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

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

custom counter

GMT+8, 2018-5-25 23:25

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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