机器学习之数学基础(六)~时间复杂度和空间复杂度

目录

算法背景 background

1. 时间复杂度 Time Complexity

1.1 时间复杂度分类

1.1.1 O(1) 常数阶

1.1.2 O(n) 线性阶

1.1.3 O(n^2) 平方阶 

1.1.4 O(logn) 对数阶

1.1.5 O(nlogn) 线性对数阶

1.1.6 O(2^n) 指数阶

1.1.7 O(n!) 阶乘阶

1.1.8 时间复杂度分类 

1.2 时间复杂度 Rules

1.3 时间复杂度计算流程

2. 空间复杂度 Space Complexity

参考 


算法背景 background

核心Algorithms + Data Structures = Programs

-》高性能的代码 = 相应速度快的代码。需要初级程序员了解算法,灵活地运用算法。

-》发明设计一款算法:要去推导证明算法的可行性

数据结构是为算法服务的,而算法又需要作用在特定的数据结构上。

-》谁的算法快,谁的算法更优!!

如果两种算法实现的速度差不多,那我们还可以去评价算法所占用的空间。

时间复杂度:执行当前算法所消耗的时间。--》快

空间复杂度:执行当前算法所消耗的内存空间。--》省

1. 时间复杂度 Time Complexity

时间复杂度 time complexity:全称为算法的渐进时间复杂度,表示执行当前算法的最高运算次数,记作T(n)=O(f(n)),表示算法的执行时间与数据规模n之间的增长关系。

核心:分析算法时间复杂度的关键在于分析出代码循环了多少次!

Note:时间复杂度反映的只是一个趋势,也就是随着n的变化,算法执行时间的也是会变化的。

1.1 时间复杂度分类

1.1.1 O(1) 常数阶

本质:复杂度与数据规模n无关! 

public static void print(int n){int a = 1;int b = 2;int c = 3;int sum = a + b + c;System.out.println(sum);
}

1.1.2 O(n) 线性阶

对应:单层for循环

public static void print1(int n){int a = 0;  // 复杂度:Tfor (int i=0;i<n;i++){System.out.println(i);  // 复杂度:n*T}
}

假设每一行代码的执行时间是T,那上段代码的执行时间T(n)=  T+n*T=(n+1)T.

->算法时间复杂度 Rule 1: 常量可以被忽略。

所以,T(n) = nT = O(n). 

1.1.3 O(n^2) 平方阶 

 双层循环平方阶O(n^2)

三层循环立方阶O(n^3)

K层循环就是K次立方阶。

1.1.4 O(logn) 对数阶

对应:while 循环

e.g. 二分查找,二叉树问题 

public static void print2(int n){int i=1;while (i <= n) {i = i * 2;}
}

分析算法时间复杂度的关键在于分析出while循环了多少次。

1->2->4->8...

2^x=n,只要能得到x的值,就得到了循环次数。

x = {log_2}^{n} = O({log_2}^{n})

同理, {log_3}^{n} = {log_3}^{2} * {log_2}^{n} = O({log_2}^{n}),不管底数是多少,最终都可以转换为以2为底的对数阶 =》O({log_2}^{n}) = O({log}^{n})

=》算法时间复杂度 Rule 2: 当循环中下标以指定倍数形式衰减,那么这就是一个对数阶。

1.1.5 O(nlogn) 线性对数阶

时间复杂度 = 代码执行次数!

for (int j=1;j<=n;j++){int i=1;   // 时间复杂度 O(n)while (i <= n) {i = i * 2;  // 时间复杂度 O(logn)}
}

嵌套代码的时间复杂度O(nlog_n) = 单独的嵌套内循环 * 单独的嵌套外循环 O(n) * O(logn)

= 嵌套内外循环时间复杂度之和 O(n) + O(nlogn)

1.1.6 O(2^n) 指数阶

def exponential(n: int) -> int:"""指数阶(循环实现)"""count = 0base = 1# 细胞每轮一分为二,形成数列 1, 2, 4, 8, ..., 2^(n-1)for _ in range(n):for _ in range(base):count += 1base *= 2# count = 1 + 2 + 4 + 8 + .. + 2^(n-1) = 2^n - 1return count

单独的嵌套内循环次数无法计算 

无法利用乘积求时间复杂度,只能用加法了 

嵌套外循环时间复杂度 O(n) 

 base:1, 2, 4, 8, 2^(n-1)

嵌套内循环次数:等比数列求和公式S_n = a \frac{1-r^n}{1-r} \rightarrow 2^n-1

1.1.7 O(n!) 阶乘阶

def factorial_recur(n: int) -> int:"""阶乘阶(递归实现)"""if n == 0:return 1count = 0# 从 1 个分裂出 n 个for _ in range(n):count += factorial_recur(n - 1)return count

1.1.8 时间复杂度分类 

最好时间复杂度、最坏时间复杂度、平均时间复杂度

1.2 时间复杂度 Rules

  • 只要是常数级别,不论n多大,代码效率都是一样的。
  • 忽略常量、低次幂和高次幂系数。
  • 嵌套代码的时间复杂度O(nlog_n) = 单独的嵌套内循环 * 单独的嵌套外循环 O(n) * O(logn)

    = 嵌套内外循环时间复杂度之和 O(n) + O(nlogn)

  • 在同一个算法中,存在明确大小关系的,可以直接取最大值作为这个算法的复杂度。

多项式时间复杂度关系:O(1) < O(log_n) < O(n) < O(nlog_n) < O(n^2) < O(n^3)

指数时间复杂度关系:O(n^2) < O(2^n) < O(n!) < O(n^n) 

1.3 时间复杂度计算流程

Note:只有可运行的语句才会增加时间复杂度,除了循环外,其他可执行语句的时间复杂读都是O(1),可以被忽略。 

(1) 计算出基本操作的执行次数T(n). 计算算法中每条语句的执行次数;在做算法分析时,一般默认为考虑最坏的情况,而不是考虑循环break or continue情况

(2) 计算出T(n)的数量级。忽略常量、低次幂和高次幂系数。

(3) 用O表示时间复杂度。只保留最高项

for(i=1;i<=n;++i){for(j=1;j<=n;++j){c[ i ][ j ]=0; //该步骤属于基本操作 执行次数:n^2for(k=1;k<=n;++k)c[ i ][ j ]+=a[ i ][ k ]*b[ k ][ j ]; //该步骤属于基本操作 执行次数:n^3}} 

第一步计算基本语句执行次数:T(n)= n^2+n^3;
第二步T(n)的同数量级,我们可以确定 n^3为T(n) 的同数量级;
第三步用大O表示时间复杂度:T(n) =O(n^3)。 

2. 空间复杂度 Space Complexity

空间复杂度 space complexity:全称为算法的渐进空间复杂度,表示执行当前算法所消耗的内存空间。是指一个算法在运行过程中临时占用存储空间大小的度量,记作S(n)=O(f(n)),用来表示算法的存储空间雨数据规模n之间的增长关系。

核心:以最差的输入数据为准;以算法运行中的峰值内存为准

  • 定义一个常数变量,与n无关,它的空间复杂度为O(1).
  • 定义一个数组,数组长度为n,这个数组需要的空间复杂度为O(n),因为它的空间随着n变化而变化。
  • 二维数组,空间复杂度O(n^2) 

参考 

https://www.cnblogs.com/lonely-wolf/p/15674526.html

一文搞懂算法的时间复杂度与空间复杂度_算法与复杂度的关系-CSDN博客

2.3   时间复杂度 - Hello 算法

2.4   空间复杂度 - Hello 算法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/21808.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

03-07Java自动化之JAVA基础之循环

JAVA基础之循环 一、for循环 1.1for循环的含义 for&#xff08;初始化语句;条件判断;条件控制或–&#xff09;{ ​ //代码语句 } 1、首先执行初始话语句&#xff0c;给变量一个起始的值 2、条件判断进行判断&#xff0c;为true&#xff0c;执行循环体中的代码语句 ​ …

3DGS语义分割之LangSplat

LangSplat是CVPR2024的paper. 实现3DGS的语义分割&#xff08;可文本检索语义&#xff09; github: https://github.com/minghanqin/LangSplat?tabreadme-ov-file 主要思想是在3DGS中加入了CLIP的降维语义特征&#xff0c;可用文本检索目标&#xff0c;实现分割。 配置环境&…

网线水晶头为什么要按标准线序打

网线接水晶头为什么要按照线序接&#xff1f; 减少串扰和增强信号质量&#xff1a; 双绞线的设计是为了减少信号间的串扰&#xff08; Crosstalk&#xff09;&#xff0c;每一对线芯在传输过程中通过相互扭绞抵消外部电磁干扰。按照标准线序接线能够确保每一对线芯之间的信号传…

Ubuntu server 24 (Linux) 安装部署smartdns 搭建智能DNS服务器

SmartDNS是推荐本地运行的DNS服务器&#xff0c;SmartDNS接受本地客户端的DNS查询请求&#xff0c;从多个上游DNS服务器获取DNS查询结果&#xff0c;并将访问速度最快的结果返回给客户端&#xff0c;提高网络访问速度和准确性。 支持指定域名IP地址&#xff0c;达到禁止过滤的效…

Pinia的介绍、使用及持久化

Pinia介绍 什么是Pinia&#xff1f; Pinia 是 Vue 的最新 状态管理工具&#xff0c;状态就是数据。 通俗地讲&#xff1a;Pinia 是一个插件&#xff0c;可以帮我们管理 vue 通用的数据 (多组件共享的数据)。 比如一份数据有多个组件需要使用&#xff0c;在学Pinia之前我们需…

Accelerate 笔记:保存与加载文件

保存和加载模型、优化器、随机数生成器和 GradScaler 使用 save_state() 将上述所有内容保存到一个文件夹位置使用 load_state() 加载之前通过 save_state() 保存的状态通过使用 register_for_checkpointing()&#xff0c;可以注册自定义对象以便自动从前两个函数中存储或加载 …

vue3+electron+typescript 项目安装、打包、多平台踩坑记录-mac+linux(包括国产化系统)

上一章《vue3electrontypescript 项目安装、打包、多平台踩坑记录》&#xff0c;我们讲了vue3electrontypescript的项目安装和windows 32位、64位的打包。这一节我们来看下mac和linux平台的打包和一些坑。 mac 经过上一章我们的踩坑后&#xff0c;再到mac环境&#xff0c;这里…

“雪糕刺客”爆改“红薯刺客”,钟薛高给了消费品牌哪些启示?

夏日袭来&#xff0c;一支价格高昂却让人眼前一亮的雪糕&#xff0c;曾一度成为市场热议的焦点。然而&#xff0c;随着消费者对性价比的日益关注&#xff0c;曾经的“雪糕刺客”钟薛高&#xff0c;其创始人林盛近期以直播带货红薯开启他的还债之路&#xff0c;高打情怀“直播自…

关于序列化与反序列化解题

1、[安洵杯 2019]easy_serialize_php <?php$function $_GET[f];function filter($img){$filter_arr array(php,flag,php5,php4,fl1g);$filter /.implode(|,$filter_arr)./i;return preg_replace($filter,,$img); }if($_SESSION){unset($_SESSION); }$_SESSION["use…

《数据资产》专题:《数据资产》如何确权、估值? 《数据产权》如何明确、保护?

2020 年 04 月 10 日&#xff0c;《中共中央国务院 关于“构建更加完善的要素市场化配置体制机制”的意见》正式公布&#xff0c;将数据确立为五大生产要素&#xff08;土地、资本、劳动力以及技术&#xff09;之一&#xff0c;数据要素市场化已成为建设数字中国不可或缺的一部…

python系列29:压测工具locust

1. 介绍 使用pip进行安装&#xff0c;下面是个简单例子&#xff1a; from locust import HttpUser, taskclass HelloWorldUser(HttpUser):taskdef hello_world(self):self.client.get("/hello")self.client.get("/world")然后打开web页面&#xff1a; 点…

大尺寸图像分类检测分割统一模型:Resource Efficient Perception for Vision Systems

论文题目&#xff1a;Resource Efficient Perception for Vision Systems 论文链接&#xff1a;http://arxiv.org/abs/2405.07166 代码链接&#xff1a;https://github.com/Visual-Conception-Group/Localized-Perception-Constrained-Vision-Systems 作者设计了一个统一的模…

k8s牛客面经篇

k8s的pod版块: k8s的网络版块: k8s的deployment版块: k8s的service版块: k8s的探针板块: k8s的控制调度板块: k8s的日志监控板块: k8s的流量转发板块: k8s的宏观版块:

单列集合--collection

package exercise;import java.util.ArrayList; import java.util.Collection;public class CollectionDemo {public static void main(String[] args) {//注意点://Co1lection是一个接口,我们不能直接创建他的对象。//所以&#xff0c;现在我们学习他的方法时&#xff0c;只能…

【LeetCode算法】第108题:将有序数组转换为二叉搜索树

目录 一、题目描述 二、初次解答 三、官方解法 四、总结 一、题目描述 二、初次解答 1. 思路&#xff1a;由于数组nums是递增的&#xff0c;采用二分查找法来构造平衡二叉搜索树。首先&#xff0c;选择nums的中间结点作为根节点&#xff0c;然后将左部分的中间值作为左子树…

中学生学人工智能系列:如何用AI学物理

经常有读者朋友给公众号《人工智能怎么学》留言咨询如何使用人工智能学习语文、数学、英语、化学等科目。这些都是中学教师、中学生朋友及其家长们普遍关注的问题。仅仅使用留言回复的方式&#xff0c;不可能对这些问题做出具体和透彻的解答&#xff0c;因此本公众号近期将推出…

Linux基础 (十二):Linux 线程的创建与同步

本篇博客详细介绍与线程有关的内容&#xff0c;这部分也是笔试面试的重点&#xff0c;需要我们对线程有深刻的理解&#xff0c;尤其是线程的并发运行以及线程同步的控制&#xff01;接下来&#xff0c;让我们走进线程的世界&#xff0c;去理解线程&#xff0c;使用线程&#xf…

kvm学习 - 迅速上手示例

目录 kvmtool kvmsample kvmtool GitHub - kvmtool/kvmtool: Stand-alone Native Linux KVM Tool repoStand-alone Native Linux KVM Tool repo. Contribute to kvmtool/kvmtool development by creating an account on GitHub.https://github.com/kvmtool/kvmtool.git cd …

Wpf 使用 Prism 开发MyToDo应用程序

MyToDo 是使用 WPF &#xff0c;并且塔配Prism 框架进行开发的项目。项目中进行了前后端分离设计&#xff0c;客户端所有的数据均通过API接口获取。适合新手入门学习WPF以及Prism 框架使用。 首页统计以及点击导航到相关模块功能待办事项增删改查功能备忘录增删改查功能登录注册…

Vue渲染函数与JSX指南

title: Vue渲染函数与JSX指南 date: 2024/6/3 下午6:43:53 updated: 2024/6/3 下午6:43:53 categories: 前端开发 tags:Vue渲染JSX基础性能优化组件对比React JSX大项目测试策略 第1章&#xff1a;Vue.js入门 Vue.js的历史和背景 Vue.js是一个用于构建用户界面的JavaScript框…