0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何计算时间复杂度

科技绿洲 来源:Java技术指北 作者:Java技术指北 2023-10-13 11:19 次阅读

1 算法与时间复杂度

算法(Algorithm)是求解一个问题需要遵循的,被清楚指定的简单指令的集合。
算法一旦确定,那么下一步就要确定该算法将需要多少时间和空间等资源,如果一个算法需要一两年的时间来完成,那么该算法的用处就不会太大。同样如果该算法需要若干个GB的内存,那么在大部分机器上都无法使用。

一个算法的评价主要从时间复杂度和空间复杂度来考虑。

而时间复杂度是一个函数,定性描述该算法的运行时间,通常用大O符号表示。

常见的时间复杂度有O(1),O(logn),O(n),O(n^2),O(2^n)...等

那么一个算法的时间复杂度如何计算呢,下面接着讲。

2 时间复杂度计算

2.1 第一个时间复杂度计算

首先我们定义算法中的语句执行次数称为语句频度或时间频度为T(n)。即T(n)表示程序的执行次数 。

首先我们看看如下的方法1执行多少次;

public int method1(){
     System.out.println("java技术指北 等你来"); //执行1次
     return 0;          //执行1次
 }

没错,它内部一共执行2次。

那么我们来看下面的方法2执行几次:

public int method2(int n){
        for(int i = 0; i< n ; i++){
         //i = 0 执行1次,i< n 执行n+1次,i++执行n次
            System.out.println("java技术指北 等你来"); //输出语句执行n次
        }
        return 1; //return 执行一次
    }

对,它一共执行了 3n+3 次。

那么对于方法1就有 T(n) = 2;
对于方法2就有 T(n) = 3n + 3;

实际的代码肯定比示例中的代码复杂得多,去统计代码的执行次数显然不可能,所以算法一般使用T(n)的渐进估算值来反映代码的执行速度。而这个估算值我们用"时间复杂度"来表示。

所以针对方法1和方法2,如何根据T(n)估算出时间复杂度
过程如下:

  1. 对于 T(n) = 2 ,由于T(n)是一个常数,那么时间复杂度可以直接估算为 1 。所以T(n) = 2 的时间复杂度为 1。用标准的时间复杂度函数表示就是 O(1)。
  2. 对于T(n) = 3n + 3 ,随着n值得不断增长,常数3相对于3n来说可以忽略不计。而系数一般也会估算成1。相当于去掉了系数和常数,则该时间复杂度为n。用时间复杂度函数表示就是O(n)。
  3. 依次推广到如下多项式中:对于T(n) = 3n^2 + 3n + 3. 随着n值得不断增大,多项式后面的项的增长就远没有n^2的增长大,可以直接舍弃低阶项和常数项,则只保留n的次方数最大的那一项,所以它的时间复杂度就为O(n^3)。

小结一下,以上三个表达式的时间复杂度表示如下

表达式时间复杂度
T(n) = 2O(1)
T(n) = 3n + 3O(n)
T(n) = 3n^2 + 3n + 3O(n^2)

总结以上规律:

  • T(n)是常数:时间复杂度为O(1)
  • T(n)不是常数:时间复杂度为O(T(n)的最高次项并且去掉最高次项的系数)

2.2 常见循环的复杂度

下面方法1的时间复杂度为 O(1):

//时间复杂度为 O(1)
    public void m1(){
        System.out.println("java技术指北 等你来");
        System.out.println("操千曲而后晓声,观千剑而后识器");
        ...
        System.out.println("java技术指北 非你莫属");
    }

下面方法2的时间复杂度为 O(n):

//时间复杂度为 O(n)    
    public int method2(int n){
        for(int i = 0; i < n ; i++){
            System.out.println("java技术指北 等你来");
        }
        return 1;
    }

下面方法3 时间复杂度为 O(n^2):

//时间复杂度为 O(n^2)
    public void method3(int n){
        for(int i = 0; i < n ; i++){
            for(int j = 0 ; j < i ; j ++){
                System.out.println("java技术指北 等你来");
            }
        }
    }

下面方法4的时间复杂度为 O(n^2):
以下方法4中第一个循环执行Q其时间复杂度为为O(n^2)
第二个循环时间复杂度为O(n)
则整个方法的时间复杂度要舍弃变化小的部分,最终的时间复杂度为O(n^2)

//时间复杂度为 O(n^2) 
    public int method4(int n){
        for(int i = 0; i < n ; i++){
            for(int j = 0 ; j < i ; j ++){
                System.out.println("java技术指北 等你来");
            }
        }
        for(int i = 0; i < n ; i++){
            System.out.println("java技术指北 等你来");
        }
        return 1;
    }

方法5的时间复杂度依然为O(n):
由于随着n的增大,方法5种执行次数最多的是else后面的循环,所以会取执行次数最多的部分来计算时间复杂度。

//时间复杂度为O(n)
    public int method5(int n){
        if( n < 100){
            for(int i = 0; i < n ; i++){
                for(int j = 0 ; j < n ; j ++){
                    System.out.println("java技术指北 等你来");
                }
            }
        }else{
            for(int i = 0; i < n ; i++){
                System.out.println("java技术指北 等你来");
            }
        }
        return 1;
    }

2.3 其他时间复杂度计算

分析下面方法6的时间复杂度

public void method6(int n){
        for(int i = 0; i < n ; i++){
            for(int j = 0 ; j < n ; j ++){
                System.out.println("java技术指北 等你来");
            }
        }
    }

方法6执行分析
i=0 输出语句执行 n 次
i=1 输出语句执行 n-1 次
i=2 输出语句执行 n-2 次
...
...
i=n-2 输出语句执行 2 次
i=n-1 输出语句执行 1 次

总执行次数就是
T(n) = n + (n-1) + (n-2) ... + 2 + 1
= n(n+1)/2 = 1/2*n^2 =

则其时间复杂度为O(n^2)

下面我们在看方法7的时间复杂度

public void method7(int n){
        int i = 1;
  while(i< n)
  {
      i = i * 2;
  }
    }

执行情况分析:
n = 2 的时候执行1次 即 T(2) = 1
n = 4 的时候执行2次 即 T(4) = 2
n = 8 的时候执行3次 即 T(8) = 3
n = 16 的时候执行4次 即 T(16) = 4

我们发现如下规律
n = 2 的时候有 2^T(2) = 2
n = 4 的时候有 2^T(4) = 4
n = 8 的时候有 2^T(8) = 8
n = 16 的时候有 2^T(16) = 16
n = 32 的时候有 2^T(32) = 32
n = n 的时候有 2^T(n) = n

如果要把T(n)放到等式左边那么

那么时间复杂度就是

再去掉底数2 则时间复杂度为

3 时间复杂度排序

我们分析了以上几种简单循环的时间复杂度,那么既然时间复杂度是用来表示算法的执行效率的,我们对一般常见的时间复杂度进行如下排序(由快到慢)。

图片
timeComplexitiesOrder.jpg

我们再用曲线图看一下时间复杂度。

图片

从图中也可以看出,随着元素变多,指数、阶乘级别的增长是最快的。显而易见其执行效率最低。

4 时间复杂度推算

最后我们计算一下如下递推关系的算法的时间复杂度
T(n)= T(n-1) + n,其中 T(0) = 1,求T(n)的时间复杂度?

我们可以将n-1 带入上面的公式,得到 T(n-1) = T(n-2) + (n-1)
再将T(n-1) 的表达式带入到T(n)的表达式
再依次将n-2 ,n-3...带入到公式中,其演算结果如下。

T(n)= T(n-1) + n
= T(n-2) + (n-1) + n
= T(n-3) +(n-2) + (n-1) + n
......
= T(2) + 3 + ......(n-2) + (n-1) + n
= T(1) + 2 + 3 + ......(n-2) + (n-1) + n
= T(0) + 1 + 2 + 3 + ......(n-2) + (n-1) + n
= 1 + 1 + 2 + 3 + ...... + (n-1) +n

最终我们得到T(n) 的时间复杂度为O(n^2)

总结

本篇介绍了时间复杂度以及如何计算时间复杂度,相信你已经掌握了吧。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 内存
    +关注

    关注

    8

    文章

    3030

    浏览量

    74109
  • 程序
    +关注

    关注

    117

    文章

    3788

    浏览量

    81111
  • 机器
    +关注

    关注

    0

    文章

    783

    浏览量

    40748
  • 函数
    +关注

    关注

    3

    文章

    4333

    浏览量

    62705
收藏 人收藏

    评论

    相关推荐

    PCB与PCBA工艺复杂度的量化评估与应用初探!

    , 不知道如何区分普通和复杂的PCB和 PCBA的设计,并采用什么样的方式来处理。 基于上述考虑, 我们参考了业 界已有的作法, 设计了一个PCB 和 PCBA的工艺复杂度计算公式以解决这 方面
    发表于 06-14 11:15

    数据结构:第1章绪论第5讲-计算时间复杂度举例(1)#结构数据

    数据结构
    学习硬声知识
    发布于 :2022年12月17日 10:18:24

    数据结构:第1章绪论第5讲-计算时间复杂度举例(2)#结构数据

    数据结构
    学习硬声知识
    发布于 :2022年12月17日 10:18:56

    JEM软件复杂度的增加情况

    这篇文档展示了几个机构关于JEM软件复杂度的增加情况的看法,特别提出来创立一个新的Ad-hoc组,研究降低软件一般性复杂度的可能方法。
    发表于 07-19 08:25

    时间复杂度是指什么

    原理->微机原理->软件工程,编译原理,数据库数据结构1.时间复杂度时间复杂度是指执行算法所需要的计算工作量,因为整个算法的执行
    发表于 07-22 10:01

    各种排序算法的时间空间复杂度、稳定性

    各种排序算法的时间空间复杂度、稳定性一、排序算法分类:二、排序算法比较:注:1、归并排序可以通过手摇算法将空间复杂度降到O(1),但是时间复杂度
    发表于 12-21 07:48

    图像复杂度对信息隐藏性能影响分析

    针对信息隐藏中载体图像的差异性,提出一种图像复杂度评价方法,综合考虑图像的压缩特性以及图像纹理能量作为图像复杂度指标,并基于阈值划分准则对栽体图像进行复杂度分类,以几种经典的基于直方图的几种无损隐藏
    发表于 11-14 09:57 5次下载

    深度剖析时间复杂度

    相信每一位录友都接触过时间复杂度,但又对时间复杂度的认识处于一种朦胧的状态,所以是时候对时间复杂度
    的头像 发表于 03-18 10:18 1896次阅读

    如何求递归算法的时间复杂度

    那么我通过一道简单的面试题,模拟面试的场景,来带大家逐步分析递归算法的时间复杂度,最后找出最优解,来看看同样是递归,怎么就写成了O(n)的代码。
    的头像 发表于 07-13 11:30 2272次阅读

    如何求递归算法的时间复杂度

    相信很多同学对递归算法的时间复杂度都很模糊,那么这篇Carl来给大家通透的讲一讲。
    的头像 发表于 07-13 11:33 1622次阅读

    常见机器学习算法的计算复杂度

    时间复杂度不是测量一个算法或一段代码在某个机器或者条件下运行所花费的时间时间复杂度一般指时间
    发表于 10-02 12:45 818次阅读

    算法时空复杂度分析实用指南1

    我以前的文章主要都是讲解算法的原理和解题的思维,对时间复杂度和空间复杂度的分析经常一笔带过,主要是基于以下两个原因:
    的头像 发表于 04-12 14:37 525次阅读
    算法时空<b class='flag-5'>复杂度</b>分析实用指南1

    算法时空复杂度分析实用指南2

    类似的,想想之前说的数据结构扩容的场景,也许`N`次操作中的某一次操作恰好触发了扩容,导致时间复杂度提高,但总的时间复杂度依然保持在`O(N)`,所以均摊到每一次操作上,其平均
    的头像 发表于 04-12 14:38 540次阅读
    算法时空<b class='flag-5'>复杂度</b>分析实用指南2

    算法时空复杂度分析实用指南(上)

    本文会篇幅较长,会涵盖如下几点: 1、Big O 表示法的几个基本特点。 2、非递归算法中的时间复杂度分析。 3、数据结构 API 的效率衡量方法(摊还分析)。 4、递归算法的时间/空间
    的头像 发表于 04-19 10:34 842次阅读
    算法时空<b class='flag-5'>复杂度</b>分析实用指南(上)

    算法时空复杂度分析实用指南(下)

    Big O 表示法的几个基本特点。 2、非递归算法中的时间复杂度分析。 3、数据结构 API 的效率衡量方法(摊还分析)。 4、递归算法的时间/空间复杂度的分析方法,
    的头像 发表于 04-19 10:35 703次阅读
    算法时空<b class='flag-5'>复杂度</b>分析实用指南(下)