Java 数据结构与算法系列精讲之时间复杂度与空间复杂度
作者:我是小白呀 发布时间:2022-03-19 20:19:50
标签:Java,时间复杂度,空间复杂度,数据结构
概述
从今天开始, 小白我将带大家开启 Jave 数据结构 & 算法的新篇章.
算法的衡量标准
当我们需要衡量一个算法的的优越性, 通常会使用时间复杂度 (Time Complexity) 和空间复杂度 (Space Complexity) 来衡量.
时间复杂度
时间复杂度 (Time Complexity) 通常用 O(n) 表示, 用来描述一个算法运行的时间.
时间复杂度 & 空间复杂度计算规则:
用常数 1 代替运行中的所有加减, lim n->∞cn = ∞
只保留最高项, lim n->∞ n^2 + an + b = lim n->∞ n^2
最优时间复杂度
最优时间复杂度指的是在最优的情况下算法需要的运行时间.
平均时间复杂度
平均时间复杂度是指所有可能的输入实例以等概率出现的情况下, 算法需要的运行时间.
最坏时间复杂度
最坏时间复杂度指的是在最坏的情况下算法需要的运行时间. 一般使用最坏时间复杂度作为时间复杂度.
O(1)
没有循环结构, 只有普通加减的代码时间复杂度为 O(1).
例如:
int i = 1;
int j = 2;
int k = i + j; // 1+2=3
O(n)
循环 n 次的代码的时间复杂度为 O(n).
例子:
int sum = 0;
for (int i = 1; i < n; i++) {
sum += i;
}
O(n^2)
两层循环嵌套的时间复杂度为 O(n^2). 如下例子, 需要进行 2n^2 次计算
例子:
int sum = 0;
for (int i = 1; i < n; i++) {
for (int j = 0; j < n; j++) {
sum += i;
sum += j;
}
}
O(logN)
2^n = N, 所以会循环 logN 次.
例子:
int sum = 0;
for (int i = 0; i < n; i++) {
sum += i;
i *= 2;
}
空间复杂度
空间复杂度 (Space Complexity) 定义为该算法所耗费的存储空间.
O(1)
如果算法执行所需要的临时空间不会随着变量的大小而变化, 那么空间复杂度就为 O(1).
例子:
int i = 1;
int j = 2;
int k = i + j; // 1+2=3
O(n)
长度为 n 的数组占用空间为 O(n).
例子:
int[] array = new int[n]
来源:https://iamarookie.blog.csdn.net/article/details/121782719


猜你喜欢
- 本文实例讲述了C#保存listbox中数据到文本文件的方法。分享给大家供大家参考。具体实现方法如下:private void SaveLst
- 一、准备java我已经把java装到了在D盘:二、配置java环境变量点击设置,进入windows设置页面;搜索高级系统设置:在系统变量里添
- 目录概述语法索引器(Indexer)的用途重载索引器(Indexer)概述索引器(Indexer) 允许一个对象可以像数组一样使用下标的方式
- 本文实例分析了Android中ListActivity用法。分享给大家供大家参考,具体如下:程序如下:import android.app.
- 接口可以声明事件。 下面的示例演示如何在类中实现接口事件。 这些规则基本上都与实现任何接口方法或属性时的相同。在类中实现接口事件在类中声明事
- 一、启动android默认浏览器这样子,android就可以调用起手机默认的浏览器访问。二、指定相应的浏览器访问1、指定android自带的
- 实验题目:MapReduce:编程实验内容:本实验利用 Hadoop 提供的 Java API 进行编程进行 MapReduce 编程。实验
- 一、问题描述在C#中is,as,using关键字具有其特点及使用场景,其中is关键字用于检查该对象是否与给定类型兼容,as关键字用于将对象转
- 本文实例实现C#以一个收银付费的小程序演示switch case语法如何使用,读入用户选择,把用户的选择赋值给变量n,再根据用户的输入提示付
- 前一段时间粗略看了一下《深入Java虚拟机 第二版》,可能是因为工作才一年的原因吧,看着十分的吃力。毕竟如果具体到细节的话,Java虚拟机涉
- StreamAPI中的stream不能被重复消费,一旦它被使用,stream就被关闭了,别的地方再消费它就会抛IllegalStateExc
- Author:jeffreyDate:2019-04-08一、开发环境:1、mysql - 5.72、navicat(mysql客户端管理工
- 在网上学习了一种继承系统AlertDialog然后用一统一方法控制dialog显示的方法,效果还不错,但按钮栏那里的分隔线并不是想要的。于是
- 本文介绍了 SpringBoot之Controller的使用,分享给大家,具体如下:1.@Controller:处理http请求 2.@Re
- 一个基于Java Socket协议之上文件传输的完整示例,基于TCP通信完成。除了基于TCP的二进制文件传输,还演示了JAVA Swing的
- <foreach>标签动态增删改查mybatis<foreach>有的时候在项目中需要查询某个列表时,可能会在代码中
- 最近完成的差不多的项目突然需要加退款的流程需求了,所以来小小的实现以下。其实对比其他的支付和退款来说,支付宝算是特别专业,也是特别简单的一个
- C语言时用if...else...来控制异常,Java语言所有的异常都可以用一个类来表示,不同类型的异常对应不同的子类异常,每个异常都对应一
- Java类加载基本过程详细介绍基本过程:根据类的全限定名称加载定义类的二进制字节流。将字节流代表的静态存储结构转化为方法区的运行时数据结构内
- 1. 将对象转换为JSON字符串,返回值为一个JSON字符串public static String toJson(Object value