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

一亩三分地论坛

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

[Leetcode] if "(i > cur &&nums[i] == nums[i-1]) continue;

[复制链接] |试试Instant~ |关注本帖
oio14644 发表于 2016-12-1 14:13:48 | 显示全部楼层 |阅读模式

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

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

x
这样为什么能去重呢, 看到3sum, 4sum, subset, 和permutation 里面很多这样写来去重的?

我原来以为是因为 nums 和 nums[i-1] 相同,  


https://discuss.leetcode.com/top ... -easy-understand/16

cuyuan
Reputation:  3


For those who don't understand how to avoid duplicate by:
if "(i > cur && cand == cand[i-1]) continue;
when we should skip a number? not just it's the same as previous number, but also when it's previous number haven't been added!
i > cur means cand[i - 1] is not added to the path (you should know why if you understand the algorithm), so if cand == cand[i-1], then we shouldn't add cand.
This tricky is very smart.

看到这回复,感觉不是这样的,有点晕了,求解惑
谢谢



 楼主| oio14644 发表于 2016-12-1 16:32:17 | 显示全部楼层
stellari 发表于 2016-12-1 15:57
backtracking就是个不断试错的过程。比如input=[1,3,4,4,4,5,6,8]. target = 11
那么首先,我们的第一个数 ...

感谢大神的讲解!
回复 支持 1 反对 0

使用道具 举报

全球28万学生4.7分推荐
stellari 发表于 2016-12-1 15:57:01 | 显示全部楼层
backtracking就是个不断试错的过程。比如input=[1,3,4,4,4,5,6,8]. target = 11
那么首先,我们的第一个数字先试input[0]=1,如果所有第一个数字为1的情况都试遍了还是不行;就试第一个数字为input[1] = 3的情况;如果还不行就试第一个数字为input[2] = 4的情况。。。以此类推。所以我们用一个循环来表示**试遍当前数字的所有可能**,而每次循环里的递归来表示**在取当前数字的情况下,进一步尝试**

那好,问题来了,如果我们发现第一个数字为input[2] = 4时的所有情况都试遍了以后,发现还是没有解。那这时你还需要再去试input[3]=4吗?当然不需要,因为第一个数字为4的所有情况都已经试过了啊。所以这时候,就应该跳过input[3]了。

那么具体什么时候该跳过?就是取了当前这个数字后的所有情况都已经被试过一次。因此,它必须是本次循环之前被试过的数字,因此判定方法是cand[ i ] == cand[ i - 1]。 i > cur是为了保证 i- 1是个合法的值。

评分

1

查看全部评分

回复 支持 反对

使用道具 举报

本版积分规则

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

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

关闭

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

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

custom counter

GMT+8, 2018-5-25 08:02

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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