• 前言
    我们在前面的排序算法的学习中了解到了,排序算法的分类,效率的比较所使用到的判断标准,就包括时间复杂度和空间复杂度,当时因为这两个定义还是比较难以理解的,所以决定单独开一篇文章,记录一下学习的过程.
    ***
  • 关于时间复杂速度与空间复杂度的基本了解
    学习一项知识之前,首先要做的,就是对它要有一个基本的了解,这里我们先来看看这两者的相关的介绍:

在计算机科学中,算法的时间复杂度(Time complexity)是一个函数,它定性描述该算法的运行时间。这是一个代表算法输入值的字符串的长度的函数。时间复杂度常用大O符号表述,不包括这个函数的低阶项和首项系数。使用这种方式时,时间复杂度可被称为是渐近的,亦即考察输入值大小趋近无穷时的情况。

空间复杂度(Space Complexity)是对一个算法在运行过程中临时占用存储空间大小的量度,记做S(n)=O(f(n))。类似于时间复杂度的讨论,一个算法的空间复杂度S(n)定义为该算法所耗费的存储空间,它也是问题规模n的函数。渐近空间复杂度也常常简称为空间复杂度。

我们通过定义简单的分析可以得出的几条简单的信息:

  • 时间复杂度和空间复杂度都是一个函数,而函数则时用来表述两个元素之间的某一种关系的,所以时间复杂度,空间复杂度都不是指具体的某个值.

  • 时间复杂度定性的描述算法的运行时间,说明时间复杂度是用来描述算法的运行速度的某种函数关系的,

  • 空间复杂度是对算法需要占用的临时空间的量度,它类似于时间复杂度,也是一个函数,是关于一个问题规模为n和其消耗的内存空间的一个函数,这里我们就知道了,空间复杂度其实是类似于时间复杂度的,是相对于时间,从内存占用方面对算法的一个描述.

  • 不管时间复杂度还是空间复杂度,都是基于一个问题规模n与时间,或内存之间的函数关系.


  • 时间复杂度的理解

通过上面的简单了解,我们再深入理解其含义,明白了其实通俗来说,就是当一个算法输入的值为n的时候,算法所需要消耗的时间.

例如一个算法对于任何大小为n的输入,其运行时间为5n^3+3n,那么它的渐近时间复杂度就是O(n^3).我们知道,其实时间复杂度表示的就是渐近时间复杂度,通常都会去除函数关系中的系数和低阶项.应为当n趋近无穷大时,它们没用多大的意义,而时间复杂度所考察的就是当n趋近于无穷大时,其需要运行的时间和n的关系,所以直接就直接使用渐近时间复杂度来描述.

需要注意的时这里的n,并不是指我们所输入的指的大小,而是我们所输入数据的长度,通过前面的排序算法的学习,我们应该能够很清楚的了解到了,n就是表示需要排序的序列长度,即包含多少个需要排序的数据而不是指一个数据的大小

而在我们实际生活中,每个程序的运行时间都需要实际测算才能知道的,所以我们不可能直接通过时间来计算时间复杂度,那样不实际,那么我们通过什么来计算时间复杂度呢.我们知道一个程序的运行时间与程序的命令执行次数时相关,理论上,每条相同的执行运行的时间时相同的,所以我们在计算某个算法的时间复杂度的时候,只需要判断其操作单元(能够实现算法的基本程序指令集合)所需要执行的次数即可.

  • 一些常见的时间复杂度

我们都知道,函数是描述两者这件的一种关系的,而时间复杂度就是一个函数,所以我们可以将一些常见的函数关系总结起来:

我们再来通过函数图像看看几种常见时间复杂的比较

这里可以很明显的看出各时间复杂度的优劣关系.


对于一个算法,其时间复杂度和空间复杂度往往是相互影响的。当追求一个较好的时间复杂度时,可能会使空间复杂度的性能变差,即可能导致占用较多的存储空间;反之,当追求一个较好的空间复杂度时,可能会使时间复杂度的性能变差,即可能导致占用较长的运行时间.。算法的时间复杂度和空间复杂度合称为算法的复杂度。

空间复杂度其实和时间复杂度类似,而在通常情况下,时间复杂度和空间复杂度是不能兼并的,对于递归算法,可以很简短,一般效率会比较快,但空间占用多.非递归方法通常较为复杂,不会消耗较多的空间,但其效率一般都不会很高.


参考:
时间复杂度--维基
空间复杂度--百科


更新时间:
2019-4-7
19:30

[Java初探外篇]__关于时间复杂度与空间复杂度的更多相关文章

  1. [Java初探外篇]__关于正则表达式

    正则表达式通常用于判断语句之中,用来检测一段字符串是否满足某一个格式.在日常生活中被广泛的用于各种用户输入信息的检测上. 而正则表达式实际上是一些具有特殊意义的字符序列.通过这些特殊字符构成的特殊序列 ...

  2. [java初探外篇]__关于StringBuilder类与String类的区别

    前言 我们前面学习到String类的相关知识,知道了它是一个字符串类,并且了解到其中的一些方法,但是当时并没有太过注意到String类的特点,今天就StringBuilder类的学习来比较一下两者的区 ...

  3. 【java初探外篇01】——关于Java修饰符

    本文记录在学习Java语言过程中,对碰到的修饰符的一些疑问,在这里具体的拿出来详细学习和记录一下,以作后续参考和学习. Java修饰符 Java语言提供了很多修饰符,但主要分两类: 访问修饰符 非访问 ...

  4. 【Java初探外篇02】——关于静态方法与实例方法

    在Java的学习中,我们知道,方法的使用是不可或缺的重要部分,在我们编写第一个Java程序hello world的时候,我们就要开始使用主方法main():它就是一个静态方法(static metho ...

  5. [java初探总结篇]__java初探总结

    前言 终于,java初探系列的学习,要告一阶段了,java初探系列在我的计划中是从头学java中的第一个阶段,知识主要涉及java的基础知识,所以在笔记上实在花了不少的功夫.虽然是在第一阶段上面花费了 ...

  6. [Java初探实例篇02]__流程控制语句知识相关的实例练习

    本例就流程控制语句的应用方面,通过三个练习题来深入学习和巩固下学习的流程控制语句方面的知识,设计到,if条件判断语句,switch多分支语句,for循环语句及其嵌套多层使用,while循环语句. 练习 ...

  7. [java核心外篇]__Object类与对象类型的转型

    前言 我们在之前的学习中提过很多次了,java是面向对象的,java的基础可以说是建立在类和对象上面的.然后我们又学到了类的继承,发现了在java类库中,类的继承是极为普遍的,一个类继承另一个类,就像 ...

  8. 【Java初探实例篇01】——Java语言基础

    示例系列,将对每节知识辅以实际代码示例,通过代码实际编写,来深入学习和巩固学习的知识点. IDE:intellij IDEA: 语言:Java 本次示例:Java语言基础知识的应用. 创建包day_4 ...

  9. Java中ArrayList和LinkedList区别 时间复杂度 与空间复杂度

    一般大家都知道ArrayList和LinkedList的大致区别:      1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构.      2.对于随机访问 ...

随机推荐

  1. (转)VmWare下安装CentOS6图文安装教程

    转自:http://www.cnblogs.com/seesea125/archive/2012/02/25/2368255.html 第一次使用VmWare和CentOS6,中间遇到不少问题,记性不 ...

  2. (转)EntityFramework.Extensions

    转自:http://www.symbolsource.org/Public/Metadata/NuGet/Project/EntityFramework.Extended/1.0.0.20/Relea ...

  3. 20145232 韩文浩 《Java程序设计》第4周学习总结

    教材学习内容总结 · Chapter 继承与多态 继承:避免多个类间重复定义共同行为.继承可以理解为一个对象从另一个对象获取属性的过程. 所有Java的类均是由java.lang.Object类继承而 ...

  4. hdu 4923 单调栈

    http://acm.hdu.edu.cn/showproblem.php?pid=4923 给定一个序列a,元素由0,1组成,求一个序列b,元素在0~1之间,并且保证递增.输出最小的∑(ai−bi) ...

  5. struts2 18拦截器详解(十)

    ModelDrivenInterceptor 该拦截器处于defaultStack中的第九的位置,在ScopedModelDrivenInterceptor拦截器之后,要使该拦截器有效的话,Actio ...

  6. How to give a math lecture

    摘自 http://www.timhsu.net/courses/generic/proof.pdf   或 http://www.timhsu.net/courses/generic/how-to- ...

  7. golang 本地构建包

    说点废话 为小胖做一个温馨提示的功能,思路已经整理好.今天使用goquery的时候,发现已经修改了.其中需要一个golang.org/x/net/html这个包,但是官网已经被万恶的GFW给墙了.这里 ...

  8. C# 在WPF中使用Exceptionless异常日志框架

    登录http://exceptionless.com/官网,注册一个账户. 创建项目 选择wpf项目类型 拷贝下箭头指的这个密钥,过后程序里用的到. 下面我们打开vs,新建一个wpf的项目 打开git ...

  9. ovs flow 原理及实验

    OpenFlow概述 在支持OpenFlow的交换机中包含了若干个Flow table,Flow table可以用来控制数据包的处理,交换机会执行与flow相匹配的表项中所罗列的动作. OpenFlo ...

  10. JQuery Mobile - 自定义图标!

    环境 jquery1.9.1.js jquery mobile 1.4.2版 图标制作 18x18px 底透明的png图标 使用图标,这个过程开始怎么弄都不行,只有个灰色的圆出现,不见图标:或者出现图 ...