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

在计算机科学中,算法的时间复杂度(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. lua rc4算法实现

    由于项目需要,用python django写restful接口遇到瓶颈,python django+uwsgi处理请求是会阻塞的, 如果阻塞请求不及时处理,会卡住越来越多的其它的请求,导致越来越多的5 ...

  2. Java异常、事件、多线程

    异常     捕捉异常,以便程序继续执行,同时可进行异常处理使程序更加健壮.     Throwble类,派生Exception类和Error类,Exception类供应用程序用,Error类系统保留 ...

  3. 学习c++需要知道

    1.c++投入和经济产出比目前较低,c++很复杂,学习难度高.周期长.而且开发效率低. 2.但是c++趋紧于完美语言,它囊括了多种编程范型.它运行效率高,对计算机有着极致的控制能力.适用于低层. 3. ...

  4. dropzone 上传插件

    dropzone dropzone.js是一个可预览的上传文件工具,不依赖任何框架(如jQuery),且具有可定制化.实现文件拖拽上传,提供AJAX异步上传功能. 1. html文件 dropzone ...

  5. kafka参数

    转载地址http://debugo.com/kafka-params/ ############################# System ########################### ...

  6. Java学习介绍

    Java版本介绍 JavaME:微型版,用于开发小型设备.智能卡.移动终端应用(使用率较低) JavaSE:标准版,用于创建桌面应用(企业用JavaSE创建桌面应用较少) JavaEE:企业版,用于创 ...

  7. 3、利用GDB进行程序调试

    本文将用一个实际例子讲解如何通过GDB进行程序调试. 首先,我们需要理解的是GDB是GNU开源组织发布的一个强大的UNIX下的程序调试工具,其产生和调试的目的是让调试者知道,程序在执行时内部发生了什么 ...

  8. 使用EF操作Oracle数据库小计

    1.建表 CREATE TABLE item.ORDERS( ORDERID ) CONSTRAINT PK_ORDERS PRIMARY KEY, ORDERNO ), STOREID ), STO ...

  9. 10 个免费的Bootstrap Admin 主题,模板收集

    In designing websites today, one of the must have frameworks is the twitter bootstrap. To those who ...

  10. <string.h>的学习

    感觉学习代码库最好的方法就是运行一下. 下面附上结果和示例代码 #include <stdio.h> #include <string.h> int main(){ const ...