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

文章目录

    • 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.mzph.cn/web/27199.shtml

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

相关文章

【论文阅读】《Sketch and Refine: Towards Fast and Accurate Lane Detection》

Abstract 车道检测是指确定道路上车道的精确位置和形状。尽管目前的方法已经做出了努力&#xff0c;但由于现实世界场景的复杂性&#xff0c;这仍然是一项具有挑战性的任务。无论是基于建议的方法还是基于关键点的方法&#xff0c;现有方法都无法有效、高效地描绘车道。基于建…

程序猿大战Python——容器——知识补充

字典遍历方法 目标&#xff1a;了解遍历字典的遍历方法。 当要遍历字典的元素内容&#xff0c;即获取字典的键、值。 常用方法&#xff1a; 函数名含义keys()以列表的形式&#xff0c;返回一个字典所有的键。values()以列表的形式&#xff0c;返回一个字典所有的值。items()返…

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

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

在微信小程序中安装和使用vant框架

目录 1、初始化项目2、安装vant相关依赖3、修改 app.json4、修改 project.config.json5、构建npm6、使用示例 本文将详细介绍如何在微信小程序中安装并使用vant框架&#xff5e; 开发工具&#xff1a;微信开发者工具 1、初始化项目 从终端进入小程序项目目录&#xff0c;执行…

JDK8时间类,时区,时间和格式化

一.时间类 二.获取所有的时区 1.获取所有的时区Set<String> zoneIds ZoneId.getAvailableZoneIds();System.out.println(zoneIds.size()); 根据打印的结果可以看到java类中一共有603个时区。 三.获取当前系统默认的时区 ZoneId zoneId ZoneId.systemDefault();Syste…

linux搭建harbor镜像仓库

安装docker-compose&#xff1a;安装docker-compose_安装 docker-compose-CSDN博客 安装harbor&#xff0c;我安装的是v2.4.3 #下载安装包 wget https://github.com/goharbor/harbor/releases/download/v2.4.3/harbor-offline-installer-v2.4.3.tgz#解压 tar -zxvf harbor-off…

618全面开战,抖音电商头部品牌罗拉密码突然“不干”了?

前言&#xff1a; 随着618电商大战的硝烟渐浓&#xff0c;各大电商平台纷纷摩拳擦掌&#xff0c;准备在这场年度购物盛宴中大展拳脚。然而&#xff0c;在这热闹非凡的氛围中&#xff0c;一个熟悉的名字却显得格外低调——罗拉密码。作为抖音电商领域的头部品牌&#xff0c;罗拉…

文心智能体体验,打造你自己的GPTs应用

利用百度智能体搭建的《RPG冒险游戏大作战》已经发布啦&#xff01; RPG冒险游戏大作战 玩家扮演一位小小勇士女孩&#xff0c;从被巨龙毁灭的冒险小镇出发&#xff0c;一路披荆斩棘&#xff0c;集齐四件神器后&#xff0c;打败巨龙&#xff0c;夺回小镇的安宁&#xff01; 整…

常见机器学习的原理及优略势

有监督 一、线性回归&#xff08;Linear Regression) 1. 算法原理 线性回归&#xff08;Linear Regression&#xff09;是一种基本的回归算法&#xff0c;它通过拟合一个线性模型来预测连续型目标变量。线性回归模型的基本形式是&#xff1a;y w1 * x1 w2 * x2 … wn * …

Java_中间件——Redis

Redis 介绍&#xff1a; Redis是一个基于内存的key-value结构数据库&#xff08;MySQL是通过数据文件方式存储在磁盘上&#xff0c;数据结构是二维表&#xff09; 特点&#xff1a; 更改配置文件&#xff1a; 使用密码&#xff1a; redis默认是不需要密码的&#xff0c;如果…

2024全国大学生信息安全竞赛(ciscn)半决赛(华南赛区)Pwn题解

前言 找华南赛区的师傅要了一份半决赛的Pwn题&#xff0c;听说只有一道题。 题目很简单&#xff0c;可以申请任意大小chunk&#xff0c;并存在UAF、DoubleFree漏洞。 还给了后门函数&#xff0c;不过限制是edit只能写8字节的数据到chunk中。 MyHeap 逆向分析 拖入IDA分析…

Linux--MQTT简介

一、简介 MQTT &#xff08; Message Queuing Telemetry Transport&#xff0c;消息队列遥测传输&#xff09;&#xff0c; 是一种基于客户端服务端架构的发布/订阅模式的消息传输协议。 与 HTTP 协议一样&#xff0c; MQTT 协议也是应用层协议&#xff0c;工作在 TCP/IP 四…

计算机系统的主要概念

这篇文章通过研究“hello&#xff0c;world”这个简单程序的生命周期来介绍计算机系统的主要概念。 1. 信息就是位 上下文 我们以 hello 程序为例&#xff0c;在 linux 系统中&#xff0c;我们编辑文本文件 hello.c&#xff0c;使用编译器将其编译成可执行的 源程序&#xf…

收银系统源码-千呼新零售2.0【连锁店财务管理】

千呼新零售2.0系统是零售行业连锁店一体化收银系统&#xff0c;包括线下收银线上商城连锁店管理ERP管理商品管理供应商管理会员营销等功能为一体&#xff0c;线上线下数据全部打通。 适用于商超、便利店、水果、生鲜、母婴、服装、零食、百货等连锁店使用。 详细介绍请查看下…

k8s学习--helm的详细解释及安装和常用命令

文章目录 Helm简介什么是Helm主要组件核心概念chart结构总结 应用环境一、helm部署二、helm基础使用 Helm简介 什么是Helm Helm 是 Kubernetes 的一个包管理工具&#xff0c;它允许用户定义、安装和升级复杂的 Kubernetes 应用程序。Helm 通过使用 “Charts” 的概念来简化应…

Zig标准库:最全数据结构深度解析(1)

最近新闻看到17岁中专女生拿下阿里全球数学竞赛第12名。咱们学习标准库中的数据结构是和学习数学是一脉相承的&#xff0c;结构体很多&#xff0c;也非常枯燥&#xff0c;但是不能全面解读过一遍&#xff0c;你很难写出合理的代码。所以&#xff0c;这一章节我们开始深度解析Zi…

关于投标中的合理均价基准差径靶心法(KIMI回答)

投标中的合理靶心法到底是什么呢&#xff1f;用了KIMI来进行回答&#xff1a;

基于uni-app和图鸟UI的智慧校园圈子小程序开发实践

摘要&#xff1a; 随着教育信息化和“互联网教育”的快速发展&#xff0c;智慧校园建设已成为推动校园管理现代化、提高教育教学质量的重要手段。本文介绍了基于uni-app和图鸟UI开发的智慧校园圈子小程序&#xff0c;旨在通过一站式服务、个性化定制、数据互通和安全可靠等特点…

Base64编码方式的介绍及其编码解码

一、Base64是什么 Base64是一种用于将二进制数据编码为ASCII字符的编码方式&#xff0c;主要目的是为了能够在文本环境中传输和存储二进制数据。这种编码方式广泛应用于电子邮件、HTTP协议和其他需要传输或存储二进制数据的地方。 二、发明Base64编码的原因 Base64编码的发明解…

202479读书笔记|《你是人间的四月天》——谁又能参透这幻化的轮回, 谁又大胆的爱过这伟大的变幻?

202479读书笔记|《你是人间的四月天》——谁又能参透这幻化的轮回&#xff0c; 谁又大胆的爱过这伟大的变幻&#xff1f; 散文诗歌书信 《你是人间的四月天&#xff08;果麦经典&#xff09;》作者林徽因&#xff0c;才女的散文&#xff0c;诗歌&#xff0c;书信集选。很值得一…