首页 > 编程语言 >[数据结构与算法·C++] 笔记 1.4 算法复杂性分析

[数据结构与算法·C++] 笔记 1.4 算法复杂性分析

时间:2024-09-22 13:48:29浏览次数:10  
标签:1.4 f1 f2 函数 cg C++ 表示法 算法

1.4 算法复杂性分析

算法的渐进分析

  • 数据规模 n 逐步增大时, f(n)的增长趋势
  • 当 n 增大到一定值以后,计算公式中影响最大的就是 n 的幂次最高的项
  • 其他的常数项和低幂次项都可以忽略

大O表示法

  • 函数f,g定义域为自然数,值域非负实数集
  • 定义: 如果存在正数c和n,使得对任意的 n > = n 0 n >=n_0 n>=n0​,都有 f ( n ) ≤ c g ( n ) f(n)≤cg(n) f(n)≤cg(n)
  • 称 f ( n ) f(n) f(n) 在集合 O ( g ( n ) ) O(g(n)) O(g(n)) 中,简称 f ( n ) 是 O ( g ( n ) ) f(n)是 O(g(n)) f(n)是O(g(n)) 的, 或 f ( n ) = O ( g ( n ) ) f(n)= O(g(n)) f(n)=O(g(n))
  • 大 O 表示法: 表达函数增长率上限
  • 一个函数增长率的上限可能不止一个
  • 当上、下限相同时则可用 Θ 表示法(大O最常用, 大Θ也可简单看作大O)

大O表示法的单位时间

  • 简单布尔或算术运算

  • 简单 I/O

    • 指函数的输入/输出
    • 例如,从数组读数据等操作
    • 不包括键盘文件等 I/O
  • 函数返回

大 O 表示法的运算法则

  • 加法规则: f 1 ( n ) + f 2 ( n ) = O ( m a x ( f 1 ( n ) , f 2 ( n ) ) ) f_1(n)+f_2(n)=O(max(f_1(n),f_2(n))) f1​(n)+f2​(n)=O(max(f1​(n),f2​(n)))

    • 顺序结构,if 结构,switch 结构
  • 乘法规则: f 1 ( n ) ⋅ f 2 ( n ) = O ( f 1 ( n ) ⋅ f 2 ( n ) ) f_1(n)·f_2(n) =O(f_1(n)·f₂(n)) f1​(n)⋅f2​(n)=O(f1​(n)⋅f2​(n))

    • for, while, do-while 结构 (复杂度相乘)
    • 例如:
      for(i=0; i<n; i++)
        for (j=i; j<n; j++)
          k++;
      
      • 上述两个循环的复杂度为 n 2 = n ⋅ n n^2=n \cdot n n2=n⋅n

大Ω表示法

  • 定义 :如果存在正数c和 no,使得对所有的 n ≥ n 0 n≥n_0 n≥n0​都有 f ( n ) ≥ c g ( n ) f(n)≥ cg(n) f(n)≥cg(n), 则称 f(n) 在集合 Ω ( g ( n ) ) Ω(g(n)) Ω(g(n)) 中,或简称 f ( n ) f(n) f(n) 是 Ω ( g ( n ) ) Ω(g(n)) Ω(g(n)) 的,或 f ( n ) = Ω ( g ( n ) ) f(n)=Ω(g(n)) f(n)=Ω(g(n))
  • 大 O表示法和大 Ω 表示法的唯一区别在于不等式的方向而已
  • 采用大 Ω 表示法时,最好找出在函数增值率的所有下限中那个最"紧"(即最大)的下限


复杂度增长率函数曲线
f ( n ) f(n) f(n)值越大, 复杂度增长率越高, 效率越低

时空权衡

  • 增大空间开销可能改善算法的时间开销
  • 可以节省空间,往往需要增大运算时间

标签:1.4,f1,f2,函数,cg,C++,表示法,算法
From: https://blog.csdn.net/qq_42995393/article/details/142419699

相关文章

  • 【代码随想录Day24】回溯算法Part03
    93.复原IP地址题目链接/文章讲解:代码随想录视频讲解:回溯算法如何分割字符串并判断是合法IP?|LeetCode:93.复原IP地址_哔哩哔哩_bilibiliclassSolution{List<String>result=newArrayList<>();LinkedList<String>path=newLinkedList<>();publicL......
  • C++ 异步 async future 等
    async和future这个和C#的Task有点像。#include<iostream>#include<string>#include<memory>#include<future>#include<thread>usingnamespacestd;intcalculate(){std::this_thread::sleep_for(std::chrono::seconds(2));......
  • C++ std::call_once 实现单例模式
    #if1#include<iostream>#include<memory>#include<mutex>usingnamespacestd;classSingleton{public:staticSingleton&getInstance(){std::call_once(m_OnceFlag,&Singleton::init);return*m_Insta......
  • 算法解析:二分查找实现整数平方根
    题目:给你一个非负整数 x ,计算并返回 x 的算术平方根 。由于返回类型是整数,结果只保留整数部分 ,小数部分将被舍去。注意:不允许使用任何内置指数函数和算符,例如 pow(x,0.5) 或者 x**0.5 。示例1:输入:x=4输出:2示例2:输入:x=8输出:2解释:8的算术平方根是2.82842.........
  • 【C/C++】速通涉及string类的经典编程题
    【C/C++】速通涉及string类的经典编程题一.字符串最后一个单词的长度代码实现:(含注释)二.验证回文串解法一:代码实现:(含注释)解法二:(推荐)1.函数isalnum介绍:2.函数tolower介绍:3.代码实现:三.翻转字符串II:区间部分翻转代码实现:(含注释)四.翻转字符串III:翻转字符串中的单词代......
  • 初识算法
    持续更新数据结构与算法专题,欢迎关注.......1.1什么是算法?定义在数学和计算机科学领域,算法是一系列有限的严谨指令,通常用于解决一类特定问题或执行计算Inmathematicsandcomputerscience,analgorithm(/ˈælɡərɪðəm/)isafinitesequenceofrigorousinstru......
  • leetcode 算法题目学习笔记 - 序号1
    1.两数之和https://leetcode.cn/problems/two-sum/简要说明:1.给定一个数组和一个数字2.要求找到数组中某两个元素,使得他们相加等于所给数字(将所给数字拆为数组中的某两个个元素)3.以数组形式返回两个下标否则返回空指针返回的下标没有顺序要求假设有唯一解,即只能在数组中......
  • 01背包问题之背包容量为什么要倒序遍历?(以C++代码具体实现为例)
    首先是先阐述一下背包问题:有n件物品和一个最多能背重量为w的背包。第i件物品的重量是weight[i],得到的价值是value[i]。每件物品只能用依次,求解将哪些物品装入背包里物品价值总和最大。这里不解释代码的其他部分,只对代码中的背包容量遍历进行具体的解释,首先给出遍历部分的代......
  • C++ 笔试常用算法模板
    C++笔试常用算法模板一、二叉树遍历DFSBFS二、回溯模板三、动态规划01背包朴素版本滚动数组优化完全背包朴素版本滚动数组优化最长递增子序列朴素版本贪心+二分优化最长公共子序列最长回文子串四、图建图邻接矩阵邻接表图的遍历DFSBFS拓扑排序并查集最小生成树Kr......
  • C++: 使用红黑树模拟实现STL中的map和set
    目录1.红黑树的迭代器++和--2.改造红黑树3.set的模拟实现4.map的模拟实现5.RBTree的改造代码博客主页:酷酷学正文开始1.红黑树的迭代器迭代器的好处是可以方便遍历,是数据结构的底层实现与用户透明打开C++的源码我们可以发现,其实源码中的底层大概如下......