我感觉 LeetCode 上面对于代码的要求苛刻

2015-02-13 15:01:14 +08:00
 wdy1184
新手,在leetcode上面做twosum.
第一次用迭代器
报错,超时
第二次用数组下标
报错,超时
要求苛刻我觉得很好!我会继续努力的.
6433 次点击
所在节点    程序员
32 条回复
hcymk2
2015-02-13 15:05:05 +08:00
我用java刷完50%的 题目 还没碰到time out 这是 LeetCode在歧视java么?
ant_sz
2015-02-13 15:18:47 +08:00
two sum 应该可以用 O(nlogn) 的时间复杂度搞定。如果不是 O(nlogn) 过不了太正常了
exch4nge
2015-02-13 15:27:13 +08:00
确定你是用O(nlogn)或更小的时间复杂度搞定的,但还是超时的话,看看你是不是把自己调试打印的语句没注释掉……
binux
2015-02-13 15:27:38 +08:00
这。。LeetCode 上面的题都太简单了,完全是在考 bug free 而不是算法的。。
gandblack
2015-02-13 15:28:24 +08:00
不苛刻吧,话说Median of Two Sorted Arrays 写明要log(m+n)的时间复杂度,,你怎么破
或者two sum也写明要求 O(nlogn)的时间复杂度你就不会纠结下标还是迭代了
ivanlw
2015-02-13 15:36:35 +08:00
two sum 不是没有用O(n)做出来的面试直接刷掉吗?
caizixian
2015-02-13 15:52:34 +08:00
rangercyh
2015-02-13 15:56:34 +08:00
@binux 说的对,leetcode的题目确实不是考难度,而是考bug free,其实很适合算法新手做
caizixian
2015-02-13 15:57:16 +08:00
@wdy1184 其实我用的也是数组下标法,关键用了Python,就把dict当array用了下。

@binux @ivanlw 求看有无更好地实现
ivanlw
2015-02-13 16:07:01 +08:00
@caizixian 利用不同编程语言的hash set类型(不同语言有不同的叫法,C++是#include <unordered_set>,Java和Python的麻烦自己找一下)的look up time是O(1)的特性,跑一次就行了,举个例子吧(2, 7, 11, 15)找22:

定义一个hashset就暂时叫a吧,一开始a是空的;先跑到2,找一下a里面有没有22-2=20(时间O(1)), 没有,把2存进a;然后7,找一下a里面有没有22-7=15,没有,把7存进去;跑到11,找一下a里面有没有22-11=11,没有把11存进去;跑到15,找一下a里面有没有22-15=7,有,所以两个数字就是7和15
caizixian
2015-02-13 16:09:26 +08:00
@ivanlw 我就是这么写的。不过这样算作弊吧
gandblack
2015-02-13 16:34:08 +08:00
@ivanlw 不是O(n)直接刷掉?有没有这么狠。。。。求一个时间空间复杂度都O(n)的解法
wilsoncao
2015-02-13 17:23:12 +08:00
@binux @rangercyh 我觉得bug free就很难了。。。
DaniloSam
2015-02-13 17:39:21 +08:00
```python
class Solution:
# @return a tuple, (index1, index2)
def twoSum(self, num, target):
result = {}
for i, n in enumerate(num, 1):
if target - n not in result:
result[n] = i
else:
return result[target - n], i

return ()
```

用hash table,O(n)啊不会超时啊
JackWindows
2015-02-13 19:28:20 +08:00
@binux 说出了我的心声。各位大神如果真想锻炼的话去做noi.openjudge.cn吧
GtDzx
2015-02-13 19:44:58 +08:00
@JackWindows 赞!没想到还有人知道noi.openjudge.cn这个题库。这个题库完成的话应该是很好的练习去处。
twistoy
2015-02-13 19:47:33 +08:00
@JackWindows OIer?
udonmai
2015-02-13 21:59:30 +08:00
每个人随便交个最 naive 的方法就过了,leetcode 也就没存在的必要了。。所以它多卡一点时间太正常了。。再者,你随便写了个方法想都不想就过了,你能学到什么。。
wdy1184
2015-02-13 22:19:03 +08:00
@DaniloSam 我用的是C++,不要剧透哦,我想自己来~
wdy1184
2015-02-13 22:19:34 +08:00
@hcymk2 没用java,可能java有更好的方法吧

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/170743

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX