lddongdong 2022-10-10 16:35 采纳率: 100%
浏览 43
已结题

一个时间复杂度的问题

img

img


为什么圆圈3那里得到O(1/6 n^3)呢?满足1<=k<=j<=i<=n的所有(i,j,k)有多少组,为什么三个变量一共有6种可能的大小关系呢?

  • 写回答

4条回答 默认 最新

  • 关注

    当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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 10月20日
  • 已采纳回答 10月12日
  • 创建了问题 10月10日

悬赏问题

  • ¥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 如何实现统一的请求异常信息提示?