lua中的运行时间
2020-12-7 8:14:46
收藏:0
阅读:126
评论:1
所以我有以下问题:
function f(n)
local z=1
for a=1,n do
for b=1,z do
for c=1,z do
z=z+1
end
end
end
return z
end
然后它给我选项:
给出以下问题的最佳答案。
f(n) = ...
O(2^(2^n)) O(2^(2^(2^(2^(2^(2^n)))))) O(2^n) O(2^(2^(2^n))) O(2^(2^(2^(2^(2^n))))) 其他 O(2^(2^(2^(2^n))))
这是我所学的lua计算课程,我不知道该怎么做,我明白有一个三重循环,很可能,如果它们都是'n'而不是'z',那么它将是'O(n^3)',但是对于我来说,我不太确定。
我希望有人能帮助/解释如何处理这样的问题。
谢谢。
点赞
评论区的留言会收到邮件通知哦~
推荐文章
- Lua 虚拟机加密load(string.dump(function)) 后执行失败问题如何解决
- 我想创建一个 Nginx 规则,禁止访问
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?

首先,
z=z + 1该操作执行的次数等于函数结束时z-1的值。因此,如果我们可以对f(n)进行分析,那么f函数的复杂度将为O(f(n))。让我们试着这样做。其次,我们简化函数。以下循环
for c=1,z do z=z+1 end等同于
z=z*2。接下来,以下循环for b=1,z do z=z*2 end等同于
z=z*(2^z)。现在我们可以等效地将整个函数重写成以下伪代码:function f(n) local z=1 for a=1,n do z=z*(2^z) end return z end现在我们可以递归地表示
f(n):最后,让我们近似计算
f(n):其中
a^^b = a^a^a^a^a...^a // a 在 b 次(这是 Knuth 的上箭头符号表示幂的运算符)。我猜对于任何正常量
c>0,当n足够大时,以下不等式成立:2^^n > c * 2^(2^(2^(2^(2^(2^n))))),因此问题的正确答案是 "其他都不是"。但是,我可能是错的。您可以在 Computer Science StackExchange 上问问,对于
f(n)=2^(f(1) + f(2) + ... f(n-1)),O(f(n))是什么。