一.简单的复杂度分析

O(1) O(n) O(logn) O(logn) O(n^2)

大O描述的是算法的运行事件和输入数据之间的关系

Eg:

数组求和

public static int sum(int[] nums){
int sum = 0;
for(int num:nums){
sum += num;
}
return sum;
}

O(n),n为nums中的元素个数。算法和n呈线性关系。

忽略常数,实际时间T=c1*n+c2。

T = 2 *n +2  O(n)

T = 2000*n + 10000 O(n)

T=1*n*n+0 O(n^2)

T=2*n*n+300n+10 O(n^2)

大O为渐进事件复杂度,描述n趋近于无穷的情况

Eg:

1.添加操作

addLast(e)  O(1)

addFirst(e)    O(n)

add(index, e)    分析方法,严格计算需要概率论计算期望  O(n/2) = O(n)

整体来说,添加操作为O(n)的操作,通常情况下,考虑是最坏的情况

2.resize O(n)

3.删除操作

removeLast()    O(1)

removeFirst()    O(n)

remove(index, e)    O(n/2) = O(n)

整体来说,删除操作为O(n)的操作

4.修改操作

set(index, e)  O(1)    数组优势:支持随机访问

5.查询操作

get(index)  O(1)

contains(e)   O(n)

find(e)   O(n)

总体来说

增:O(n)

删:O(n)

改:已知索引O(1);未知索引O(n)

查:已知索引O(1);未知索引O(n)

二.均摊时间复杂度与复杂度的震荡

1.均摊复杂度

假设capacity = n,n+1次addLast,触发resize,总共进行2n+1次基本操作

平均,每次addLast(e)操作,进行2次基本操作

这样均摊计算,均摊时间复杂度是O(1)的。  与当前size无关

removeLast(e)同理

2.复杂度的震荡

同时看addLast和removeLast操作

当capacity = n,此时size = n,addLast(e)与removeLast(e)都会触发resize

addLast  扩容O(n)

removeLast 缩容 O(n)

addLast 扩容O(n)

removeLast 缩容O(n)

......

产生了复杂度的震荡

出现问题原因:removeLast时resize过于着急(Eager)

解决方案:Lazy

remove方法中,当size=capacity/4,才将capacity减半,同时需要保证缩容得到的数组空间data.length/2!=0

        if(size == data.length / 2 && data.length / 2 != 0)
resize(data.length/2);

<数据结构基础学习>(二)简单的时间复杂度分析的更多相关文章

  1. Go基础学习(二)

    数组[array] 数组定义[定义后长度不可变] 12 symbol := [...]string{USD: "$", EUR: "€", GBP: " ...

  2. Python入门基础学习 二

    Python入门基础学习 二 猜数字小游戏进阶版 修改建议: 猜错的时候程序可以给出提示,告诉用户猜测的数字偏大还是偏小: 没运行一次程序只能猜测一次,应该提供多次机会给用户猜测: 每次运行程序,答案 ...

  3. Python基础学习二

    Python基础学习二 1.编码 utf-8编码:自动将英文保存为1个字符,中文3个字符.ASCll编码被囊括在内. unicode:将所有字符保存为2给字符,容纳了世界上所有的编码. 2.字符串内置 ...

  4. <数据结构基础学习>(四)链表 Part 1

    一.链表基础 动态数组.栈.队列底层都是依托静态数组实现的,靠resize来解决固定容量问题. 链表是真正的动态数据结构,是一种最简单的一种动态数据结构. 更深入的理解引用(或者指针). 更深入的理解 ...

  5. Django基础学习二

    今天继续学习django的基础 学习用户提交url如何获得返回值 1.首先需要在工程的urls文件定义指定的urls要路由给哪个函数 在这个例子中,我们定义home的urls路由给views里的tes ...

  6. salesforce lightning零基础学习(二) lightning 知识简单介绍----lightning事件驱动模型

    看此篇博客前或者后,看一下trailhead可以加深印象以及理解的更好:https://trailhead.salesforce.com/modules/lex_dev_lc_basics 做过cla ...

  7. python基础学习二 数据结构之list及相关基本操作

    list是py内置的一种数据类型,list就是列表的意思,list就是一种有序的数据集合,可以随时增加和删除list的元素. 生活中,比如我们要列出全班同学的名字,就可以用list来表示 >&g ...

  8. NetAnalyzer笔记 之 二. 简单的协议分析

    [创建时间:2015-08-27 22:15:17] NetAnalyzer下载地址 上篇我们回顾完了NetAnalyzer一些可有可无的历史,在本篇,我决定先不对NetAnalyzer做介绍,而是先 ...

  9. WebService基础学习(二)—三要素

    一.Java中WebService规范      JAVA 中共有三种WebService 规范,分别是JAX-WS.JAX-RS.JAXM&SAAJ(废弃).   1.JAX-WS规范    ...

随机推荐

  1. Spring Boot应用总结更新

    一.SpringBoot的产生背景: SpringBoot的产生背景伴随着微服务,微服务的相关概念参考上一篇的博客,分布式架构理论: 微服务的宏观概念理解: 将一个大应用拆分成多个小应用,一个小应用是 ...

  2. 在phpstudy中安装并使用ThinkPHP 5

        最近在慕课网学习 thinkphp,由于教师使用的是 MAC下的 MAMP 环境,而我使用的是 win7 的 phpstudy,区别不大,记录在这里,方便查询.   不同系统集成环境安装: m ...

  3. Linux 环境下 Git 安装与基本配置

    索引: 目录索引 参看代码 GitHub: git.txt 一.Linux (DeepinOS) 环境 1.安装 sudo apt-get update sudo apt-get install gi ...

  4. The account that is running SQL Server Setup does not have one or all of the following rights: the right to back up files and directories, the right to manage auditing and the security log and the rig

    安装SQL SERVER 是规则检查提示权限问题 运行secpol.msc,没有Debug program权限,添加即可,如果已加域则要在域策略修改,或退域安装后在加域.

  5. Burpsuite 之intruder

    首先工具:Burpsuite1.7,DVWA,火狐浏览器代理插件,火狐浏览器,密码字典(以下用Bp代指burpsuite) 启动Bp,启动DVWA,并打开本地代理功能 ​ 开启bp的拦截功能,并在dv ...

  6. C#多线程与并行编程方面的电子书,中英文版本

    给大家共享一些C#多线程与并行编程方面的电子书,中英文版本的. 链接: 百度网盘地址 提取码: y99a

  7. SQL其他常用的语句

    阅读目录 一:汇总数据 1.理解AVG函数 2.理解COUNT()函数 3.理解max()函数 4.理解min()函数 5.理解sum()函数 二:分组数据 1 创建分组(group by) 2 HA ...

  8. Fabric CA环境的集成

    我们前面关于Fabric的所有文章中用到的例子都没有CA Server,都是由cryptogen这个工具根据crypto-config.yaml而生成的.但是在实际生产环境中,我们肯定不能这么做,我们 ...

  9. sanic set up

    (venv) MacBook-Pro:bin shihw$ pip3 install sanicCollecting sanic Downloading https://files.pythonhos ...

  10. [看图说话]在VMware Workstation 9中安装Mac OS X 10.8 Mountain Lion

    本文环境: CPU:Intel Core i7 920: OS:Windows 7: 内存:8G: 玩Hackintosh各有各的理由,不管什么理由,利用虚拟机安装Mac OS X都是一个可行的办法. ...