Java-数据结构-时间和空间复杂度 (ಥ_ಥ)

news2024/11/17 7:25:03

目录:

一、算法效率:

1、我们如何衡量一个算法的好与坏:

2、算法效率:

二、时间复杂度:

1、概念:

2、大O的渐进表示法:

3、推导大O渐进方法:

4、时间复杂度的举例:

三、空间复杂度:

1、概念:

2、计算实例:

四、常见的复杂度:

总结:


一、算法效率:

1、我们如何衡量一个算法的好与坏:

     对于这个问题,我们需要考虑两个方面的问题:时间 和 空间。这两个方面,当这两个方面都是很好的时候呢,我们的算法就是一个好的算法了。那么我们来看看什么是时间什么又是空间呢?   

2、算法效率:

    对于我们分析我们的算法效率是我们要分析两个方面:时间效率 和 空间效率 。

时间效率:

       也可被称为时间复杂度,时间复杂度主要衡量的是一个算法的运行速度。

空间效率:

       也可被称为空间复杂度,空间复杂度主要衡量的是一个算法所需要的额外的空间。


二、时间复杂度:


1、概念:

        在计算机中,算法的时间复杂度是一个数学函数,其定量的描述了算法的执行时间。

       其实对于程序运行的时间呢,理论上我们是算不出来的,只能等待其运行的时候我们才能知道,但是呢,我们要是每一次都要执行程序才能把时间复杂度算出来的话,那么是非常的麻烦的。所以呢我们有了能大概算出时间复杂度的方法。

       一个算法所需要的时间与语句的执行次数成正比,算法中的基本操作的实行次数,就为时间复杂度。


2、大O的渐进表示法:

        就假如我们的N是10000的话,那么是不是对于整体来说我们的 2*N 和 10 就是一个非常小的数,所以在我们计算时间复杂度的时候呢,我们其实不一定需要精准的计算,而我们只需要取得最大的结过即可,这里我们使用大O的渐进法

       大O符号:是用于描述渐进行为的数学符号。

3、推导大O渐进方法:

  对于我们大O渐进方法我们要注意三点:

1、用常数 1 取代运行时间中的所有加法常数。

2、在修改后的运行次数中,只保留最高项。

3、如果做高阶存在并且不是 1 ,则除去与这个项目相乘的常数

     这之后得到的就是大O阶。

 比如我们上面的func的那个例子:

  没变化之间 F(N) = N^2 + N*2 +10

     我们变化之后为:F(N) = N^2 

由此可知我们的大O渐进法去除了那些对结果影响不大的项,简介表示了执行次数

对于有些的时间复杂度存在 最坏的、最好的和平均的情况。 

最坏的情况:

         任意输入规模的最大运行次数(上界)

最好的情况:

         任意输入规模的最小的运行次数(下界)

平均的情况:

         任意输入规模的期望运行次数

虽然呢,我们有这三种情况,但是呢在实际情况中呢,我们只是关注最坏的情况

4、时间复杂度的举例:

 1、

2、

3、 

4、 

5、 

  我们在Java中呢,我们的logN 是log以2为底的N。

6、

    对于这个递归代码来说呢。

 我们有一个公式:递归代码的时间复杂度 = 递归的次数 * 每次递归执行的次数

我们来分析一下图片中的代码:

       我们每次递归呢所执行的代码都是判断 N < 2 这个代码,所以我们可以把每次递归执行的次数看为 1 ,我们递归的次数是N所以我们最终的递归的时间复杂度为:O(N)


  我们把时间复杂度了解了之后呢,接下来我们来了解一下什么是空间复杂度。

三、空间复杂度:

1、概念:

        空间复杂度是对一个算在运行过程中法临时占用存储空间的量。

        我们要记住的是,对于空间复杂度来说,其不是计算占用了多少的byte个数,而是计算的变量的个数。

         计算空间复杂度的规则和计算时间复杂度差不多,都是使用大O的渐进法计算的。

2、计算实例:

    (1)、

       我们来看看上面的冒泡排序的空间复杂度:

(2)、

    我们再来看看我们上面的递归的例子:


四、常见的复杂度:

         O(1) < O(logN) < O(N) < O(N*logN) < O(N^2)

这是我们会常见的复杂度,这是他们之间的大小关系。


总结:

        OK,我们这次的博客分享就到这里了,让我们下次再见,对于时间复杂度和空间复杂度在数据结构中是很重要的,所以我们要尽量的去理解。拜拜~~

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

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

相关文章

【推荐】Linux 推荐软件

【推荐】Linux 推荐软件 星火应用商店 Spark-Store: 专注Linux应用适配的应用商店 专注Linux应用适配的应用商店 微信 基于wine工具;wine中的windows涉及很多DLL需要配置&#xff0c;可以借助winetricks、Q4wine&#xff0c;另外还需要一个windwos系统&#xff0c;用来复制其中…

私人诊所|基于SprinBoot+vue的私人诊所管理系统(源码+数据库+文档)

私人诊所管理系统 基于SprinBootvue的私人诊所管理系统 一、前言 二、系统设计 三、系统功能设计 系统功能实现 后台模块实现 管理员功能实现 患者功能实现 医生功能实现 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取&am…

el-table自定义合并表格

前沿 &#xff1a; 为了更好的展示数据&#xff0c;很多地方用到表格合并&#xff0c;但是element文档里面没有好的合并方法&#xff0c;只能自定义合并表格来解决需求。于是乎&#xff0c;写了以下方法&#xff0c;方面以后拿来即用。 自定义合并表格 表格数据 tableData: [{i…

图片怎么裁剪中间部分?这几种裁剪方法每个人都学的会!

图片怎么裁剪中间部分&#xff1f;在数字生活的广阔图景中&#xff0c;图片裁剪作为一项基本技能&#xff0c;其重要性日益凸显&#xff0c;这一操作不仅是对图像边界的精准界定&#xff0c;更是通往个性化表达与标准化应用的桥梁。从日常社交媒体的瞬间分享&#xff0c;到专业…

多模态工业异常检测算法整理

本文统计了MVTec 3D-AD上的多个多模态异常检测算法&#xff0c;仅对比其I-AUROC指标。数据的来源为多模态工业异常检测Benchmark | Ziuch の Blog&#xff0c;这位博主经常分享很多工业异常检测的优秀博文&#xff0c;质量很高。 MVTec 3D-AD相关的异常检测算法包含3大类&#…

智慧公厕系统,重塑公共卫生间新生态@卓振思众

在快节奏的现代生活中&#xff0c;公共卫生间作为城市基础设施的重要组成部分&#xff0c;其管理效率和使用体验直接关系到市民的生活质量。近年来&#xff0c;随着科技的飞速发展&#xff0c;智慧卫生间系统应运而生&#xff0c;以其智能化、便捷化的特点&#xff0c;正逐步改…

低代码用户中心的构建与应用

引言 在现代软件开发中&#xff0c;低代码平台因其高效、灵活、用户友好的特性而逐渐受到青睐。特别是在用户中心的构建方面&#xff0c;低代码平台能够显著提升开发效率&#xff0c;降低开发成本。本文将探讨如何利用低代码平台构建一个高效的用户中心&#xff0c;并分享一些…

树形dp + 位运算 + 差分,MC0362 异或

目录 一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 二、解题报告 1、思路分析 2、复杂度 3、代码详解 一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 码题集OJ-异或 (matiji.net) 二、解题报告 1、思路分析 考虑每个结点u&a…

工作 6 年,@Transactional 注解用的一塌糊涂

接手新项目一言难尽&#xff0c;别的不说单单就一个 Transactional 注解用的一塌糊涂&#xff0c;五花八门的用法&#xff0c;很大部分还失效无法回滚。 有意识的在涉及事务相关方法上加Transactional注解&#xff0c;是个好习惯。不过&#xff0c;很多同学只是下意识地添加这个…

Redis的ZSet底层数据结构

一、ZSet底层数据结构 typedef struct zset{// 跳表zskiplist *zsl;// 字典dict *dic; }zset类型的底层数据结构是由压缩列表或跳表、**字典&#xff08;哈希表&#xff09;**实现的。 如果zset中元素个数小于128个&#xff0c;并且每个元素的值小于64字节时&#xff0c;redi…

Prompt提示词如何写才能发挥大语言模型LLM的最大潜力

提示词 提示工程学是一门相对较新的学科&#xff0c;用于开发和优化提示&#xff0c;以便高效地利用语言模型&#xff08;LM&#xff09;来进行各种应用和研究主题。提示工程技能有助于更好地了解大型语言模型&#xff08;LLM&#xff09;的能力和限制。研究人员使用提示工程来…

错误处理与日志记录:在自动化脚本中实施的有效策略

目录 引言 错误处理机制 1. 异常捕获与处理 2. finally子句 3. 异常信息的打印输出 日志记录 1. 使用logging模块 基本配置 日志级别 日志回滚 2. 自定义日志格式 3. 多处理器和过滤器 实践案例 自动化测试中的错误处理与日志记录 脚本示例 结论 在自动化测试领…

载流子的产生与复合

文章目录 前言有三种形式能够产生载流子 前言 半导体中能贡献导电作用的电子和空穴称为载流子 有三种形式能够产生载流子 热激发&#xff08;本征激发&#xff09;&#xff1a;价带中的电子受到热激发可能会跃迁至导带&#xff0c;成为能够起导电作用的电子&#xff0c;同时对…

给自己复盘用的tjxt笔记day12第一部分

优惠券使用 优惠券规则定义 对优惠券的下列需求: 判断一个优惠券是否可用,也就是检查订单金额是否达到优惠券使用门槛 按照优惠规则计算优惠金额,能够计算才能比较并找出最优方案 生成优惠券规则描述,目的是在页面直观的展示各种方案,供用户选择 因此,任何一张优惠券都…

SpringWeb 重定向

现在前端后分离&#xff1a;如何确认是跳转到前端页面还是后端的方法呢&#xff1f;RedirectView&#xff1a;重定向如何区分重定向的是前端页面还是后端的一个controller呢 先看下&#xff1a;SpringBoot系列教程web篇之重定向-阿里云开发者社区 ## 根据浏览器中返回的状态码…

vue3中,vue-echarts基本使用(关系图、知识图谱、柱状图、饼图、折线图)

vue3 安装vue-echarts npm i -S vue-echarts echarts//cnpm 安装 cnpm i -S vue-echarts echartsvue2 注意:Vue 2 下使用 vue-echarts,必须还要安装 @vue/composition-api : npm i -D @vue/composition-api //cnpm 安装 cnpm i -D @vue/composition-api main.js中全局注册…

【支付】PayPal支付通道注册(中国大陆、香港)

PayPal支付通道分个人版和企业版&#xff0c;在注册和功能以及收费上都有所区别&#xff0c;如果在测试阶段个人版也有sandbox账户&#xff08;包括Client ID和Secret&#xff09;&#xff0c;如果要切换到生产环境&#xff0c;会让你升级为企业版&#xff0c;只有企业版才可以…

华清远见元宇宙实验中心,开启嵌入式、物联网与人工智能教学新篇章

2024年8月23日&#xff0c;在北京举行的“匠心服务智启新程”2025新品发布会上&#xff0c;华清远见教育科技集团向行业展示了其最新的科技成果。其中最引人注目的焦点之一&#xff0c;莫过于元宇宙实验中心的发布。 正值华清远见教育科技集团20周年的里程碑时刻&#xff0c;这…

【零知识证明】构建第一个zk

1 必要步骤 视频学习&#xff1a;5. Circcom 中的基本算术电路_哔哩哔哩_bilibili 文字学习&#xff1a;https://hackmd.io/YlNLZS2ESI21OSqdTW_mPw/S1jqN-h80/edit 第五课&#xff0c;circom实践&#xff0c;需要安装 1 vscode 2 rust&#xff1a;Windows安装Rust环境&…

深入了解 ThinkSNS:开源社交网络系统的强大力量

深入了解 ThinkSNS&#xff1a;开源社交网络系统的强大力量 一、概述 在如今的互联网时代&#xff0c;社交网络已成为人们生活中不可或缺的一部分。无论是企业还是个人开发者&#xff0c;都可能需要构建一个功能强大的社交平台。而在众多的解决方案中&#xff0c;ThinkSNS 脱颖…