数据结构速成

1.时间复杂度:

①简单版:

用大Ο记号表示算法的时间性能。

  将基本语句执行次数的数量级放入大Ο记号中。

  如果算法中包含嵌套的循环,则基本语句通常是最内层的循环体,如果算法中包含并列的循环,则将并列循环的时间复杂度相加。例如:

 for (i=1; i<=n; i++)

  x++;

  for (i=1; i<=n; i++)

    for (j=1; j<=n; j++)

      x++;

  第一个for循环的时间复杂度为Ο(n),第二个for循环的时间复杂度为Ο(n²),则整个算法的时间复杂度为Ο(n+n²)=Ο(n²)。

  注、加法原则:T(n)=O(f(n))+O(g(n))=O(max(fn,gn))

②复杂版:

例一:

i = n*n;
whlie(i != 1)
    i = i/2;

第一步:列出循环趟数t及每轮循环i的变化值:

t0123
in^{2}\frac{n^2}{2}\frac{n^2}{4}\frac{n^2}{8}

第二步:找到t与i的关系:

 i=\frac{n^{2}}{2^{t}}

第三步:确定循环停止条件:

i = 1

第四步:联立第二步第三步两式解方程:

\frac{n^{2}}{2^{t}} = 1 \quad\quad n^2 = 2^t \quad\quad t = \log_2n^2

t = \log_2n^2 = 2\log_2n

所以得到时间复杂度为:

T = O(\log_2n)

例二:

x = 0;
while (n>=(x+1)*(x+1))
    x = x+1;

第一步:列出循环趟数t及每轮循环x的变化值:

t01234
x01234

第二步:找到t与x的关系:

 t = x

第三步:确定循环停止条件:

n = (x+1)^2

第四步:联立第二步第三步两式解方程:

(t +1)^2 = n

t = \sqrt[]{n}-1

所以得到时间复杂度为:

T=O(\sqrt[]{n})

2.空间复杂度:

空间复杂度是对一个算法在运行过程中临时占用存储空间大小的量度。空间复杂度不是程序占用了多少字节的空间,因为这个也没太大意义,所以空间复杂度算的是变量的个数。空间复杂度计算规则基本跟时间复杂度类似,也使用大O渐进表示法。(数组)

3.栈

Push(

  • 8
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值