首页 > 编程语言 >算法效率中的基本概念

算法效率中的基本概念

时间:2023-12-12 14:22:06浏览次数:45  
标签:复杂度 最坏 效率 算法 时间 情况 基本概念 运行

算法复杂度是一个必考的知识点,常常出现在阅读程序题中,让考生进行判断。

1.先理解算法模板的复杂度计算

2.再尝试套用初赛题目中的复杂度计算

3.递归算法的复杂度可以展开计算

算法效率是评估算法性能的一个关键指标,一般而言分析算法效率的方式有两种:

  1. 时间复杂度

  2. 空间复杂度

在一般的算法分析中,考察的主要是时间复杂度。

基本操作数

算法的运行速度受计算机性能的影响,所以通常考虑算法效率的不是算法运行的实际用时,而是算法运行所需要进行的基本操作的数量。

像加减乘除、访问变量、给变量赋值等都可以看作基本操作。对基本操作的计数或是估测可以作为评判算法用时的指标。

时间复杂度

在算法竞赛中,我们衡量一个算法的效率时,最重要的不是看它在某个数据规模下的用时,而是看它的用时随数据规模而增长的趋势,即 时间复杂度

时间复杂度是指算法运行时间与问题规模之间的关系,通常用大 �O 表示法来表示。

常见的时间复杂度有O(1), O(logn), O(n), O(nlogn), O(n2), O(2n)等,其中 O(1) 表示算法的运行时间不随问题规模变化而改变,而O(2n) 则表示算法的运行时间随问题规模n呈指数级增长。

数量级函数

变化趋势意味着我们不用纠结于具体的操作次数和n之间的精确对应关系,也就是不用看具体的函数的参数是什么,而只用看随着数据范围的增大,操作次数的变化是属于哪一类函数。

例如:是常数,还是线性的,还是对数的,还是nlogn的,还是n2的,还是2n的,还是阶乘n!的。原因是当n变得非常大的时候,这些不同类型的函数之间的差异值才是明显的,而同一种类型之间的参数不同带来的差异就显得微不足道了,可以忽略不计。这也是为什么O(1)和 �(3)O(3) 都被称作 �(1)O(1)。

我们再来看个例子:

for (int i = 1; i <= n; i++) {
   j = i;
   j++;
}

这段代码的时间复杂度O(n)的。分析代码的执行次数,第1行中i=1执行1次, i<=ni++分别执行n次,第2行、第3行分别执行n次,所以这段代码总共执行4n+1次。从这个结果可以看出,这个算法的耗时是随着n的变化而变化。如果n无限大的时候,1+4n 中的常量1就没有意义了,倍数4的意义也不大。因此时间复杂度直接简化为O(n)。

时间复杂度比较

O(n)、O(logn)、O(n​)、O(nlogn)随着n的增加,复杂度提升不大,因此这些复杂度属于效率高的算法,反观O(2n)和O(n!)当n增加到50时,复杂度就突破十位数了,这种效率极差的复杂度最好不要出现在程序中。(tips:通常计算机每秒可以计算的次数大约是10的8次方)

 **logn **sqrt(n)​nlognn22nn!
n = 5 2 2 10 25 32 120
n = 10 3 3 30 100 1024 3628800
n = 50 5 7 250 2500 约10151015 约3.0∗10643.0∗1064
n = 100 6 10 600 10000 约10301030 约9.3∗101579.3∗10157
n = 1000 9 31 9000 1000 000 约1030010300 约4.0∗1025674.0∗102567

最坏、最好、平均

在进行时间复杂度分析时,需要考虑算法的最好、最坏、平均情况时间复杂度。

最好情况时间复杂度是指算法在最优输入情况下的运行时间复杂度,即在所有可能的输入情况中,算法所需的最少时间。例如,对于二分查找算法来说,在目标元素为中间元素的情况下,查找时间为 O(1)。

最坏情况时间复杂度是指算法在最劣输入情况下的运行时间复杂度,即在所有可能的输入情况中,算法所需的最长时间。例如,对于冒泡排序算法来说,最坏情况是需要 O(n2) 的时间复杂度。

平均情况时间复杂度是指算法在所有可能输入情况下的平均运行时间复杂度。对于某些算法来说,平均情况时间复杂度更能反映算法的运行效率,例如快速排序算法的平均情况时间复杂度为 O(nlogn),而最坏时间复杂度是 O(n2)。

我们通常所说的时间复杂度大 O是指算法的最坏时间复杂度。这是因为最坏时间复杂度能够给出算法的最长运行时间,可以帮助我们评估算法的性能并预估程序的执行时间。此外,最坏时间复杂度也是一种更保守的衡量指标,即使算法在最坏情况下表现较好,也能够保证算法的性能不会低于最坏时间复杂度。

空间复杂度

空间复杂度是指算法所需内存空间与问题规模之间的关系,是对一个算法在运行过程中临时占用存储空间大小的量度。它表示了算法在执行过程中所需的额外内存。

例如递归实现斐波那契数列,空间复杂度是O(n)。虽然每次调用产生两个新的递归调用fib(n - 1) + fib(n - 2),但这些调用是顺序执行的,因此实际上只需要为最深的调用序列分配空间。最深的调用序列大约有 n 个调用,所以空间复杂度为 O(n)。

标签:复杂度,最坏,效率,算法,时间,情况,基本概念,运行
From: https://www.cnblogs.com/luliusheng/p/17896697.html

相关文章

  • 项目播报 | 河北信投数字科技签约璞华科技,以数字化方式全面提升采购效率
    近日,璞华科技签约河北信投数字科技有限责任公司(以下简称“河北信投数字科技”)。璞华科技基于璞华采云链产品帮助客户打造采购数字化全景解决方案,实现智慧采购数字化转型升级。本次强强联合,双方就采购数字化平台建设达成合作,璞华科技将结合客户智慧采购业务需求,设计既能解决业务......
  • 高并发情况下的漏桶算法(javascript版)
    classLeakyBucket{//高并发情况下的漏桶算法 constructor(capacity,leakRate){//创建一个容量为capacity,每秒漏水量为leakRate的漏桶 this.capacity=capacity; this.leakRate=leakRate; this.water=0; this.lastLeakTime=Date.now(); ......
  • 小微公司为何需要CRM:提升业务效率和客户满意度
     公司作为一个组织,管理方面是重中之重。传统式的人力会是一个较为费时费力的大工程。随着科技的发展,CRM系统完全可以胜任企业管理的工作。那么,CRM有什么特点?对小微公司有哪些作用?1、提高管理效率传统的客户管理方式主要依靠人工维护、协调和沟通,往往存在信息不及时、交流不畅......
  • 一款专业的内外网文件摆渡产品,应如何帮助企业提升协作效率?
    伴随着全球数字化转型的持续深入,数字经济的蓬勃发展,数据资产已成为非常重要的生产要素。近年来,全球数据泄密事件频发,数据泄密事件的平均成本逐年攀升。考虑到业务安全需要,绝大多数企业会考虑网络隔离,在内部划分为不同的隔离网域,内网-外网,互联网-内网,生产网-办公网,办公网-研发网隔......
  • 银行如何选择跨网文件交换方案,提升业务效率?
    银行业在我国经济发展和社会运转中承载着举足轻重的作用和意义,进入互联网时代,网络的运算和数据管理能力助力银行业高速发展,但同样带来了一些网络安全隐患,网络攻击、数据窃取、敏感信息泄露等问题影响着银行业的根基。为响应和落实国家层面对于金融行业网络安全的建设要求,同时基于......
  • 【算法】【线性表】最长公共前缀
    1 题目给k个字符串,求出他们的最长公共前缀(LCP)样例1:输入:k个字符串=["ABCD","ABEF","ACEF"]输出:"A"解释:公共最长前缀是"A".样例2:输入:k个字符串=["ABCDEFG","ABCEFG","ABCEFA"]输出:"ABC&q......
  • 【新工具】从零配置Vim+Latex提升写作效率(Windows)
    1.首先安装gvimwelcomehome:vimonline2.接着安装vimplugGitHub-junegunn/vim-plug::hibiscus:MinimalistVimPluginManager或终端直接运行iwr-usebhttps://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim|`ni$HOME/vimfiles/autoload/plu......
  • 【算法】【线性表】最长连续序列
    1 题目给定一个未排序的整数数组num,找出最长连续序列的长度。样例1:输入:num=[100,4,200,1,3,2]输出:4解释:这个最长的连续序列是[1,2,3,4].返回所求长度42 解答publicclassSolution{/***@paramnum:Alistofintegers*@......
  • mbedTLS移植CTR_DRBG随机数算法
    一、概述因使用真随机数需要硬件支持,在硬件不支持时,我们需要通过软件来实现伪随机数生成器。根据NITSSP800-90A的推荐,推荐的随机数生成为HASH_DRBG、HMAC_DRBG、CTR_DRBG。本文主要介绍如何通过mbedtls移植实现CTR_DRBG生成随机数。二、mbedtls简要介绍MbedTLS是一个开源、......
  • 算法:如何实现大整数相加?
    算法题:给你两个很大很大的整数(如100位整数),如何求出它们的和?思路:小学数学竖式拆分,各个击破。在程序中列出的“竖式”究竟是什么样子呢?我们以426709752318+ 95481253129为例,来看看大整数相加的详细步骤:第一步,把整数倒序存储,整数的个位存于数组0下标位置,最高位存于数组长度-1下......