【CS.AL】算法复杂度分析 —— 渐进符号表示法

news2025/2/27 16:29:27

文章目录

    • 1 概述
    • 2 渐进符号详解
      • 2.1 大O符号(O)
      • 2.2 Ω符号(Ω)
      • 2.3 Θ符号(Θ)
      • 2.4 o符号(o)
      • 2.5 ω符号(ω)
    • 3 具体例子
      • 3.1 插入排序(Insertion Sort)
      • 3.2 二叉搜索树(Binary Search Tree)

在这里插入图片描述

1000.01.CS.AL.1.3-算法基础-渐进符号表示法-Created: 2024-06-13.Thursday17:38

1 概述

渐进符号表示法用于描述算法的时间复杂度和空间复杂度,衡量算法的性能。它可以帮助我们分析和比较不同算法的效率,尤其是当输入规模变大时。常见的渐进符号包括大O符号(O)、Ω符号(Ω)、Θ符号(Θ)、o符号(o)和ω符号(ω)。

2 渐进符号详解

2.1 大O符号(O)

大O符号(Big O Notation) 用于描述算法在最坏情况下的时间复杂度或空间复杂度,表示在输入规模趋近无穷大时,算法的增长率上限。它帮助我们理解算法的效率上限。

定义:算法的时间复杂度为O(f(n)),如果存在正数c和n0,使得对所有n ≥ n0,算法的执行时间T(n)满足T(n) ≤ c * f(n)。

示例

  • 对于线性时间复杂度的算法,如简单的遍历数组,时间复杂度为O(n)。
  • 对于二分查找算法,时间复杂度为O(log n)。

表示法

  • O(1):常数时间复杂度。
  • O(n):线性时间复杂度。
  • O(n²):平方时间复杂度。
  • O(log n):对数时间复杂度。
  • O(n log n):线性对数时间复杂度。

2.2 Ω符号(Ω)

Ω符号(Big Omega Notation) 用于描述算法在最好情况下的时间复杂度或空间复杂度,表示在输入规模趋近无穷大时,算法的增长率下限。它帮助我们理解算法的最低效率。

定义:算法的时间复杂度为Ω(f(n)),如果存在正数c和n0,使得对所有n ≥ n0,算法的执行时间T(n)满足T(n) ≥ c * f(n)。

示例

  • 对于二分查找算法,最好情况是在第一次比较时就找到目标元素,其时间复杂度为Ω(1)。
  • 对于快速排序算法,最好情况是每次都能均匀地将数组分成两部分,其时间复杂度为Ω(n log n)。

表示法

  • Ω(1):常数时间复杂度。
  • Ω(n):线性时间复杂度。
  • Ω(n²):平方时间复杂度。

2.3 Θ符号(Θ)

Θ符号(Big Theta Notation) 用于描述算法在平均情况下的时间复杂度或空间复杂度,表示在输入规模趋近无穷大时,算法的增长率的紧确界限。它帮助我们理解算法的精确效率。

定义:算法的时间复杂度为Θ(f(n)),如果存在正数c1、c2和n0,使得对所有n ≥ n0,算法的执行时间T(n)满足c1 * f(n) ≤ T(n) ≤ c2 * f(n)。

示例

  • 对于简单的遍历数组,时间复杂度为Θ(n)。
  • 对于快速排序算法,平均情况时间复杂度为Θ(n log n)。

表示法

  • Θ(1):常数时间复杂度。
  • Θ(n):线性时间复杂度。
  • Θ(n²):平方时间复杂度。

2.4 o符号(o)

o符号(Small o Notation) 用于描述算法的非渐进上界,表示在输入规模趋近无穷大时,算法的增长率严格小于某个函数。它帮助我们理解算法的上界,但并不包括等于的情况。

定义:算法的时间复杂度为o(f(n)),如果对于任意正数c,存在n0,使得对所有n ≥ n0,算法的执行时间T(n)满足T(n) < c * f(n)。

示例

  • 对于一个执行时间为2n的算法,它的时间复杂度为o(n²)。

表示法

  • o(n):小于线性时间复杂度。
  • o(n²):小于平方时间复杂度。

2.5 ω符号(ω)

ω符号(Small omega Notation) 用于描述算法的非渐进下界,表示在输入规模趋近无穷大时,算法的增长率严格大于某个函数。它帮助我们理解算法的下界,但并不包括等于的情况。

定义:算法的时间复杂度为ω(f(n)),如果对于任意正数c,存在n0,使得对所有n ≥ n0,算法的执行时间T(n)满足T(n) > c * f(n)。

示例

  • 对于一个执行时间为n log n的算法,它的时间复杂度为ω(log n)。

表示法

  • ω(1):大于常数时间复杂度。
  • ω(n):大于线性时间复杂度。
  • ω(log n):大于对数时间复杂度。

3 具体例子

3.1 插入排序(Insertion Sort)

void insertionSort(int arr[], int n) {
    for (int i = 1; i < n; i++) {
        int key = arr[i];
        int j = i - 1;

        while (j >= 0 && arr[j] > key) {
            arr[j + 1] = arr[j];
            j = j - 1;
        }
        arr[j + 1] = key;
    }
}

分析

  • 最坏情况:输入数组为降序,时间复杂度为O(n²)。
  • 最好情况:输入数组为升序,时间复杂度为Ω(n)。
  • 平均情况:时间复杂度为Θ(n²)。

3.2 二叉搜索树(Binary Search Tree)

struct Node {
    int data;
    Node* left;
    Node* right;
};

Node* search(Node* root, int key) {
    if (root == nullptr || root->data == key)
        return root;

    if (root->data < key)
        return search(root->right, key);

    return search(root->left, key);
}

分析

  • 最坏情况:树退化成链表,时间复杂度为O(n)。
  • 最好情况:树是平衡的,时间复杂度为Ω(log n)。
  • 平均情况:时间复杂度为Θ(log n)。

通过理解这些渐进符号及其应用,我们可以更好地评估算法的效率,选择合适的算法来解决实际问题。

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

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

相关文章

GitHub强制双重验证、二次验证之下载微软Authenticator

Download Microsoft Authenticator 如上图&#xff0c;安卓手机在国内&#xff0c;基本没有下载使用的可能。 下载 Microsoft Authenticator 如上图&#xff0c;找到了国内下载渠道&#xff0c;但仅联想商店的新版本适合使用&#xff0c;下载安装即可。

C++11初始化列表打包器initializer_list

有时我们无法提前知道应该向函数传递几个实参。为了编写能处理不同数量实参的函数我们使用initializer_list Cplusplus中的定义&#xff1a; 其里面有三个成员函数 也就是说他是支持迭代器的&#xff0c;支持迭代器就支持范围for 图像理解 函数类型 void Test1_initializer_li…

一手洞悉巴西slot游戏包投放本土网盟CPI广告优势

一手洞悉巴西slot游戏包投放本土网盟CPI广告优势 在巴西这片热土上&#xff0c;slot游戏包的投放本土网盟CPI广告是一项既充满挑战又富有机遇的任务。CPI&#xff08;Cost Per Install&#xff09;广告模式&#xff0c;即按安装付费&#xff0c;已经成为许多游戏开发商推广产品…

ios18新功能:设专属“咒语”动动嘴巴即可操作iphone

苹果 iOS / iPadOS 18 系统引入了“人声快捷指令”&#xff08;Vocal Shortcuts&#xff09;功能&#xff0c;即便iPhone、iPad 处于锁屏状态下&#xff0c;也能响应你的语音命令。 苹果官方对“人声快捷指令”的介绍如下&#xff1a;iPhone 和 iPad 用户可以通过人声快捷指令…

2024牛客网高频精选Java面试八股文整理(附答案)

Java 面试 Java 作为编程语言中的 NO.1,选择入行做 IT 做编程开发的人&#xff0c;基本都把它作为首选语言,进大厂拿高薪也是大多数小伙伴们的梦想。以前 Java 岗位人才的空缺&#xff0c;而需求量又大&#xff0c;所以这种人才供不应求的现状&#xff0c;就是 Java 工程师的薪…

yolo模型评估指标相关概念

mAP&#xff08;mean Average Precision 平均精度&#xff09;&#xff0c;是一个经常被用来衡量目标 检测模型是否具有较好性能的指标。 计算mAP需要先计算每一类物体的AP&#xff0c;然后取平均值&#xff0c;所以下面介绍的 TP,FP,FN,TN都是针对某一类物体&#xff08;目标&…

CATIA软件 输入无参格式还原成为有参模型教程

上图为零件设计中特征辨识的命令栏&#xff0c;此次分享是对手动/自动特征辨识的命令应用&#xff0c;作个简单操作的分享了解。在CATIA软件中把输入的无参模型通过特征化后转化为有参模型的过程。其实CATIA软件早有这个功能提供给用户使用了&#xff0c;可能大家很少用。有了手…

数据通信与网络(二)

如何构建网络协议 这些协议采用分层的结构&#xff0c;每层协议实现特定功能&#xff0c;同时也需要依靠低层协议所提供的服务。 网络协议可以理解为三部分组成&#xff1a; 1、语法&#xff1a;通信时双方交换数据和控制信息的格式&#xff0c;是对通信时采用的数据结构形式…

【Numpy】numpy.r_用法

numpy.r_[字符串, 数组, 数组] numpy.r_的这三个整数默认值是0,1,-1 numpy.c_就是numpy.r_在三个整数是-1,2,0时的特例&#xff0c;因为常用&#xff0c;所以单独拎出来了。第一个参数-1指沿最后一个轴(维度)连接 有一个shape(2, 3, 4)的数组 np.random.randint(low0, high1…

Apache Tomcat介绍

目录 前言 一、Apache Tomcat的历史 二、核心特性与组件 三、Tomcat-基本使用 总结 前言 在Java Web开发领域&#xff0c;Apache Tomcat是一个不可或缺的核心组件。作为一个轻量级的开源Web应用服务器&#xff0c;Tomcat提供了一种简单而高效的方式来部署和管理Java Servle…

课外语文杂志课外语文杂志社课外语文编辑部2024年第4期目录

悦读时刻_我读经典 从忏悔到自救——鲁迅《风筝》的心灵叙事 杨丽; 5-7 读懂文字背后的深意——以《林黛玉进贾府》为例探索小说阅读之道 舒芳; 8-10 鲁迅笔下的真实与卑微——《故乡》中的人物形象 张淑堂; 11-13《课外语文》投稿&#xff1a;cn7kantougao163.com…

LLM基础知识

LLM背景知识介绍 1 大语言模型 (LLM) 背景 大语言模型 (英文&#xff1a;Large Language Model&#xff0c;缩写LLM) 是一种人工智能模型, 旨在理解和生成人类语言. 大语言模型可以处理多种自然语言任务&#xff0c;如文本分类、问答、翻译、对话等等。 &#x1f4a5;通常&…

vivado HW_TARGET

HW_目标 描述 硬件目标hw_target是包含一个或多个JTAG链的系统板 Xilinx FPGA设备&#xff0c;您可以使用比特流文件进行编程&#xff0c;或用于调试您的设计。 系统板上的硬件目标与Vivado Design Suite之间的连接 由硬件服务器对象hw_server管理。 使用open_hw_target命令打开…

三款有3D效果的js图表库

1、G2简洁的渐进式可视化语法。https://g2.antv.antgroup.com/manual/extra-topics/3d-charts 2、 https://www.highcharts.com/https://www.highcharts.com/ 3、https://www.fusioncharts.com/charts/pie-doughnut-charts/donut-chart-in-3d?frameworkjavascripthttps://www…

聚鼎科技:现在的装饰画做起来难吗

在当代&#xff0c;装饰画作为一种体现个人品味和审美情趣的方式&#xff0c;已经广泛应用于各种室内空间。不少人会产生这样的疑问&#xff1a;在现代化技术和材料的支持下&#xff0c;制作一幅装饰画是变得容易了&#xff0c;还是依旧充满挑战? 现代科技的确为装饰画的制作带…

STM32项目分享:OV7670将图片上传电脑

目录 一、前言 二、项目简介 1.功能详解 2.主要器件 三、原理图设计 四、PCB硬件设计 1.PCB图 2.PCB板及元器件图 五、程序设计 六、实验效果 七、资料内容 项目分享 一、前言 项目成品图片&#xff1a; 哔哩哔哩视频链接&#xff1a; https://www.bilibili.c…

tailwindcss的@apply使用

tailwindcss的apply是把在html写的tailwindcss可以挪到style里面 简化页面的可读性 没写之前的 <section class"block-risk absolute flex flex-col items-center p-4 text-center left-0 text-white;" :style"{ top, left: 60px }"> </section…

【秋招突围】2024届秋招笔试-阿里系列笔试题-第二套-三语言题解(Java/Cpp/Python)

&#x1f36d; 大家好这里是清隆学长 &#xff0c;一枚热爱算法的程序员 ✨ 本系计划跟新各公司春秋招的笔试题 &#x1f4bb; ACM银牌&#x1f948;| 多次AK大厂笔试 &#xff5c; 编程一对一辅导 &#x1f44f; 感谢大家的订阅➕ 和 喜欢&#x1f497; &#x1f4e7; 清隆这边…

基于Ascend C的FlashAttention算子性能优化最佳实践

LLM的Attention部分处理给计算系统带来巨大的计算和访存压力。业界先后出现FlashAttention、FlashAttention2等算法&#xff0c;通过计算等价和切分有效降低HBM数据访问量。 昇腾异构计算架构CANN针对昇腾AI处理器的片上内存和缓存大小&#xff0c;以及数据搬运通路&#xff0…

ozon如何上架产品,ozon平台怎么上架产品

在电子商务领域&#xff0c;产品上架是商家成功运营的关键步骤之一。对于正在或计划进军俄罗斯市场的卖家来说&#xff0c;了解如何在Ozon平台高效上架产品至关重要。接下来讲解下ozon如何上架产品&#xff0c;ozon平台怎么上架产品&#xff01; 产品上架工具&#xff1a;D.DDq…