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

在计算机科学中,算法的时间复杂度(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. .net升级到4.0之后,出现;System.Windows, Version=2.0.5.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798

    今天在做从Silverlight页中跳转到aspx页的时候,出现错误: 第一次跳转的时候就出现这个错误,然后在点跳转或者刷新这个错误页面,问题就没有了. 解决方案: 在C:\Program Files ...

  2. 5.Vue临时上传文件夹

    1.在项目目录中,通过npm install multiparty进行安装必要组件npm install multiparty --save-dev 2.app.js中添加app.use(bodyPa ...

  3. #define 和typedef

    #define PI 3.1415926 #define是将数值进行定义(语法上也可以定义类型但不建议这么做,具体下面问题说) typedef int Data; rypedef是对类型进行定义 注意 ...

  4. Leetcode--680. Valid Palindrome II(easy)

    Given a non-empty string s, you may delete at most one character. Judge whether you can make it a pa ...

  5. 100度享乐电商网 CSS

    /*reset begin*/body,div,dl,dt,p,h1,h2,h3,h4,h5,input,form,span,ul{ margin: 0; padding: 0;}a{ text-de ...

  6. SRM484

    又Orz了一发rng_58.. 250pt: 题意:给定一种兔子数:当S(x*x) = S(x)*S(x)时,x为兔子数,其中S(x)表示各个数位之和. 思路:本来想了一个复杂度很高的想法..然后想看 ...

  7. hive函数 parse_url的使用

    hive提供了直接处理url的函数 parse_url desc funtion 的解释是: parse_url(url, partToExtract[, key]) - extracts a par ...

  8. AngularJS 路由 resolve属性

    当路由切换的时候,被路由的页面中的元素(标签)就会立马显示出来,同时,数据会被准备好并呈现出来.但是注意,数据和元素并不是同步的,在没有任何设置的情况下,AngularJS默认先呈现出元素,而后再呈现 ...

  9. 用光的微粒说和广义相对论来解释衍射现象 Explanation of Diffraction Phenomenon by Particle Theory of Light and General Relativity

    历史上,物理学是用波动说来解释光的衍射现象.但用微粒说结合广义相对论同样可以做到. 把光看作粒子,当经过障碍物边缘时,由于广义相对论效应,边缘附近的空间被弯曲,使得不同路径的平行光发生偏转,落在障碍物 ...

  10. Python 数据结构与算法—— 快排

    1. 先从待排序的数组中找出一个数作为基准数(取第一个数即可),然后将原来的数组划分成两部分:小于基准数的左子数组和大于等于基准数的右子数组.然后对这两个子数组再递归重复上述过程,直到两个子数组的所有 ...