有一个计算时间复杂度的算法问题需要请教一下 V 友们

2017-12-12 17:01:50 +08:00
 regicide

for(int i = 1; i <= n; i++)
    for (int j = 1; j <= log5(i); j += 3)
这样的循环(主要是第二个循环)的时间复杂度应该怎样推导呢?

888 次点击
所在节点    问与答
5 条回复
tjbwyk
2017-12-12 17:23:21 +08:00
大致如此? O((log5(n!)/3))=O(log5(n!))<=O(log5(n^n))=O(n log5(n))=O(n log(n))
tjbwyk
2017-12-12 17:25:43 +08:00
或者假设第二层循环上限是 log5(n),那原来的时间复杂度<=O(n*log5(n)/3),化简是一样的
tjbwyk
2017-12-12 17:27:41 +08:00
已经忘了怎么算了。。比如时间复杂度的下限什么的。。
regicide
2017-12-12 17:30:21 +08:00
@tjbwyk 就是有点纠结 log5(n)这个点 感谢 看来我还得回去仔细看看书
tjbwyk
2017-12-12 17:33:56 +08:00
@regicide 是 log5->log 么?换底之后可以提一个常数项出来

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

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

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

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

© 2021 V2EX