鱼C论坛

 找回密码
 立即注册
查看: 5196|回复: 1

[已解决]时间复杂度的分析

[复制链接]
发表于 2021-9-17 22:30:20 | 显示全部楼层 |阅读模式
5鱼币
请问这个时间复杂度应该怎么求解?谢谢大家!!
   [ 答案是O(N^4) ]
sum=0;
for(i=1;i<N;i++)
    for(j=1;j<i*i;j++)
        if(j%i==0)
            for(k=0;k<j;k++)
                 sun++;
最佳答案
2021-9-17 22:30:21
本帖最后由 兔子不吃窝边草 于 2021-9-19 18:07 编辑

最后一行为sum;
由5,6行可知循环了j次;
分析第4行,j%i为0说明j为i的倍数;
由第3行分析,j为1到i^2-1,所以j可以为i*1,i*2,…,i*(i-1),共计为i*(1+2+…+i-1)=1/2 * i^2 *(i-1),复杂度为i^3;
由第2行可知i为1到N-1,共计1^3+2^3+…+(N-1)^3,倒序相加推得1/2*( (1^3+(N-1)^3)+(2^3+(N-2)^3)+…+((N-1)^3+1^3)),每一项的复杂度为N^3,共N-1项,所以复杂度为N^4。

最佳答案

查看完整内容

最后一行为sum; 由5,6行可知循环了j次; 分析第4行,j%i为0说明j为i的倍数; 由第3行分析,j为1到i^2-1,所以j可以为i*1,i*2,…,i*(i-1),共计为i*(1+2+…+i-1)=1/2 * i^2 *(i-1),复杂度为i^3; 由第2行可知i为1到N-1,共计1^3+2^3+…+(N-1)^3,倒序相加推得1/2*( (1^3+(N-1)^3)+(2^3+(N-2)^3)+…+((N-1)^3+1^3)),每一项的复杂度为N^3,共N-1项,所以复杂度为N^4。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-9-17 22:30:21 | 显示全部楼层    本楼为最佳答案   
本帖最后由 兔子不吃窝边草 于 2021-9-19 18:07 编辑

最后一行为sum;
由5,6行可知循环了j次;
分析第4行,j%i为0说明j为i的倍数;
由第3行分析,j为1到i^2-1,所以j可以为i*1,i*2,…,i*(i-1),共计为i*(1+2+…+i-1)=1/2 * i^2 *(i-1),复杂度为i^3;
由第2行可知i为1到N-1,共计1^3+2^3+…+(N-1)^3,倒序相加推得1/2*( (1^3+(N-1)^3)+(2^3+(N-2)^3)+…+((N-1)^3+1^3)),每一项的复杂度为N^3,共N-1项,所以复杂度为N^4。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-22 07:56

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表