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

一亩三分地论坛

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

[Leetcode] 贡献我的LeetCode四种语言的刷题答案

[复制链接] |试试Instant~ |关注本帖
include110 发表于 2015-12-11 12:15:18 | 显示全部楼层 |阅读模式

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

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

x
现在只写了86道题,后面会同步更新,以前一直是按照C、C++、Python、Java四种语言写的,现在为了刷题速度,只好选一种来做了,后面慢慢在同步更新补上

评分

3

查看全部评分

 楼主| include110 发表于 2015-12-11 12:15:45 | 显示全部楼层
回复 支持 1 反对 0

使用道具 举报

全球28万学生4.7分推荐
WilsonWu123 发表于 2015-12-12 12:57:48 | 显示全部楼层
良心大作 赞!
回复 支持 反对

使用道具 举报

macrofun 发表于 2015-12-12 20:54:50 | 显示全部楼层
楼主良心做品。
PS。 可否先看一下 leetcode上第316题 Remove Duplicate Letters。?
回复 支持 反对

使用道具 举报

 楼主| include110 发表于 2015-12-12 22:43:41 | 显示全部楼层
macrofun 发表于 2015-12-12 20:54
楼主良心做品。
PS。 可否先看一下 leetcode上第316题 Remove Duplicate Letters。?

参考了一下大神的作品,刚上来也没看到解法,此题用贪心策略+栈解决,代码如下:
char* removeDuplicateLetters(char* s) {
    int i,len=0,top=0,hash[26],tag[26];
    char* res;
    memset(hash,0,sizeof(hash));
    memset(tag,0,sizeof(tag));
    for(i=0;s;i++){
        if(tag[s-'a']==0){
            tag[s-'a']=1;
            len++;
        }
        hash[s-'a']=i;
    }
    res = (char*)malloc(sizeof(char)*(len+1));
    memset(tag,0,sizeof(tag));
    for(i=0;s;i++){
        if(tag[s-'a']==0){
            while(top>0 && s<res[top-1] && hash[res[top-1]-'a']>i){
                tag[res[top-1]-'a'] = 0;
                top--;
            }
            tag[s-'a'] = 1;
            res[top++] = s;
        }
    }
    res[top]=0;
    return res;
}
首先维持一个hash数组,保存每个字符的最后一个位置,也就是说如果到了这个位置就必须要把这个字符添进去了,否则就会漏掉这个字符,
对于每一个字符,如果栈顶元素比这个字符大并且这个栈顶元素在该字符后面仍然可以出现,那么这个位置就可以暂时让给该字符,则删除栈顶元素加入我们的新字符,一直重复这个步骤直到找不到可以删除的字符为止。
对于这个条件 if(tag[s-'a']==0)可以这样来看,如果我在栈中已经保存了这个字符,那么这个字符后面可能有三种情况,一种是没有字符,那么再来一个一样的字符我们不用考虑;还有就是有字符但是比该字符小,这种情况只会出现在有的这个字符后面没有再出现这个字符了,那么仍然不用考虑;第三种就是有字符但是比该字符大,这种情况更加不能考虑添加新字符,因此都跳过不考虑。




回复 支持 反对

使用道具 举报

小民 发表于 2016-1-18 06:16:01 | 显示全部楼层
include110 发表于 2015-12-11 12:15
Github网址是:https://github.com/include110/LeetCodeSolution

感謝樓主分享。
建議使用BITBUCKET, 有私有倉庫。
回复 支持 反对

使用道具 举报

本版积分规则

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

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

关闭

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

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

custom counter

GMT+8, 2018-5-25 03:51

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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