差异检查是否在默认数据中是否有钥匙?
假设house
是默认数据。
house=defaultdict(int)
用纪念编写递归代码时两个以下的区别有什么区别?
if house[i]:
...
我
if i in house:
...
认为第二个是正确的方法, 当我尝试使用第一个时,我得到了TLE(超过时间限制),但我不知道为什么。 我想知道为什么第二个是正确的。
Suppose house
is defaultdict.
house=defaultdict(int)
What's the difference between below two when writing Recursion Code with Memoization?
if house[i]:
...
and
if i in house:
...
I think the second one is the right way,
and when I tried with the first one, I got TLE(Time Limit Exceed) but I don't know why.
I want to know why the second one is correct.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
前者有两个问题:首先是,如果相应的密钥不存在,它将在字典中创建一个键值对,然后返回0,这在判断中是有效的:
第二个问题是,如果键已经存在,但是相应的值为0或其他真实价值为false的值,判断将是错误的:
The former has two problems: first is if the corresponding key does not exist, it will create a key value pair in the dictionary, and then return 0, which is valid in judgment:
The second problem is that if the key already exists, but the corresponding value is 0 or other value which truth value is false, the judgment will be wrong: