为什么圆圈3那里得到O(1/6 n^3)呢?满足1<=k<=j<=i<=n的所有(i,j,k)有多少组,为什么三个变量一共有6种可能的大小关系呢?
一个时间复杂度的问题
为什么圆圈3那里得到O(1/6 n^3)呢?满足1<=k<=j<=i<=n的所有(i,j,k)有多少组,为什么三个变量一共有6种可能的大小关系呢?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
4条回答 默认 最新
- 技术专家团-小桥流水 2022-10-10 17:50关注
当i=1时,内层for循环执行次数是1=1
当i=2时,内层for循环执行次数是1 + (1+2)=4
当i=3时,内层for循环执行测试是 1+(1+2)+(1+2+3)=10
当i=4时,内层for循环执行测试是 1+(1+2)+(1+2+3)+(1+2+3+4)=20
...
当i=n时,内层for循环执行测试是 1+(1+2)+(1+2+3)+(1+2+3+4)+ ...+(1+2+..+n)
相当于a(n)=a(n-1)+n(n+1)/2,这个数列最后a(n)的表达式为:
a(n)=n(n+1)(n+2)/6
时间复杂度取幂次最高的项就是 1/6n^3本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
- ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
- ¥15 帮我写一个c++工程
- ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
- ¥15 关于smbclient 库的使用
- ¥15 微信小程序协议怎么写
- ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
- ¥20 怎么用dlib库的算法识别小麦病虫害
- ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
- ¥15 uniapp uview http 如何实现统一的请求异常信息提示?