比如有一个两层的循环,如果是
n = 0
for i in range(10):
for j in range(10):
n += 1
print(n) // 100
复杂度应该是 n^2 吧,那这样呢:
n = 0
for i in range(10):
for j in range(i, 10):
n += 1
print(n) // 55
相当于 10 + 9 + 8 + ... + 1 = 55,这个复杂度应该怎么描述?
两个循环还好理解,如果是三层循环呢:
n = 0
for i in range(10):
for j in range(i, 10):
for k in range(j, 10):
n += 1
print(n) // 220
主要是三层循环就想不明白了,求教这怎么理解呢?
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.