我无法在 leetcode 中记住这个问题?我做错了什么?
问题链接: https://leetcode.com/problems/nique-paths/nique-paths/
与回忆但需要相同的时间: httpps://leetcode.com/leetcode.com/submissions/submissions/detail/detail/detail/detail/672801459/
我已经编写了记忆的代码,但是有些行动,请告诉我我在做什么错。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
记忆不是问题,
我只是认为即使实现按照您预期的方式工作,它仍然太慢,您可能有多达 10 亿条路径需要探索,每条路径可能需要 100 多个步骤。
用组合学尝试
另一种方法是从组合学的角度看问题:
注意每条路径如何由向下或向右移动的列表表示
所以路径总数就是排列向下和向上移动的方式数
从原来的问题中,我们可以看到有
m-1
向下移动和n-1< /code> 向上移动。
在组合学中,我们说结果是
(m-1) + (n-1)中m-1的组合
下面是一些可以做到这一点的代码:
Memoization is not the problem
I just think that even if the implementation works the way you intend it, it is still too slow, you could have up to one billion path to explore wich could each take more than 100 steps.
Try it with combinatorics
Another approach is to look at the problem from a combinatorics side:
notice how each path could be represented by a list of down or right moves
so the total number of paths is just the number of ways to arrange the down and up moves
From the original question, we can see that there are
m-1
moves down andn-1
moves up.In combinatorics, we say that the result is
the combination of m-1 in (m-1) + (n-1)
Here is some code that would do that: