算法复杂度

1 复杂度定义

空间复杂度S(n)—— 程序在执行时占用存储单元的长度。通常和输入数据的规模有关。S(n)过高可能导致内存超限,造成程序非正常中断。

时间复杂度 T(n) —— 程序在执行时耗费时间的长度。通常和输入数据的规模有关。

2 复杂度分析

下图所示为不同复杂度随着n的逐渐增大所耗费的时间复杂度。

Fig1 不同时间复杂度曲线

Fig1的复杂度分析如下:

O(2^n) > O(n^2) > O({\color{Red} nlog n)} > O({\color{Blue} n}) > O({\color{Green} log n})

  • 在算法设计时,我们应当尽可能使得复杂度最小。
  • 当算法复杂度为O(log n^2)时,应想办法变为O(n log n)。
  • 最高效的是O(log n)。

Notices:

  • 两段代码相加的复杂度为分别求复杂度,取两者中的较大者。
  • 两段代码乘积的复杂度为分别求复杂度,取两者的乘积。
  • for循环的时间复杂度为循环次数乘以循环体代码的复杂度。
  • if-else复杂度,取分支条件中的较大者。

3 应用实例

最大子列和问题。

  • 方法1:双重循环,算法的时间复杂度为O(N*N)。
int MaxSubseqSum2( int A[], int N )
{ int ThisSum, MaxSum = 0;
    int i, j;
    for( i = 0; i < N; i++ ) { /* i是子列左端位置 */
        ThisSum = 0; /* ThisSum是从A[i]到A[j]的子列和 */
        for( j = i; j < N; j++ ) { /* j是子列右端位置 */
            ThisSum += A[j];
            if( ThisSum > MaxSum ) /* 如果刚得到的这个子列和更大 */
                MaxSum = ThisSum;  /* 则更新结果 */
        }
    } 
    return MaxSum;
}
  • 方法2:在线处理,算法的时间复杂度为O(N)。
int MaxSubseqSum4( int A[], int N )
{ int ThisSum, MaxSum;
    int i;
    ThisSum = MaxSum = 0;
    for( i = 0; i < N; i++ ) {
        ThisSum += A[i];   /* 向右累加 */
        if( ThisSum > MaxSum )
            MaxSum = ThisSum;    /* 发现更大和则更新当前结果 */
        else if( ThisSum < 0 )   /* 如果当前子列和为负 */
            ThisSum = 0;  /* 则不可能使后面的部分和增大,抛弃之 */
    }
    return MaxSum
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值