【数据结构入门精讲 | 第二篇】一文讲清算法复杂度

news2024/9/23 23:32:53

在这里插入图片描述

上篇文章中我们引入了算法、数据结构、数据类型等概念,而要想衡量一个算法与数据结构是否为优质的,就需要一个衡量标准,这个衡量标准也是在我们实现一个好的算法时要遵循的原则。

目录

    • 基本概念
    • 渐进性态
    • 渐进性态数学表征
    • 算法复杂度的运算
      • 顺序搜索算法
      • 二分搜索算法

基本概念

算法复杂度是衡量算法效率的指标,它描述了算法运行时间或空间需求随着输入规模增加而增加的趋势。通常分为时间复杂度和空间复杂度两种。

时间复杂度描述了算法解决问题所需的计算时间与输入规模之间的关系。常用的时间复杂度包括常数阶O(1)、对数阶O(logn)、线性阶O(n)、线性对数阶O(nlogn)、平方阶O(n^2)等,其中O表示“大O记号”。

空间复杂度描述了算法解决问题所需的内存空间与输入规模之间的关系。类似地,常用的空间复杂度也可以用大O记号表示。

由于空间复杂度较为简单,本文主要介绍时间复杂度。

渐进性态

算法复杂度的渐进性态是指随着问题规模的增大,算法的执行时间或者空间占用的增长趋势。通常情况下,我们关注的是算法在最坏情况下的表现,因为这可以给我们一个最保守的估计。

渐进性态数学表征

上界(Upper bound):使用大 O 符号(O)表示算法的上界,描述了算法执行时间或空间占用随输入规模增长的最大限制。它给出了算法在最坏情况下的表现。

下界(Lower bound):使用大 Ω 符号(Ω)表示算法的下界,描述了算法执行时间或空间占用随输入规模增长的最小限制。它给出了算法在最好情况下的表现。下界表示算法至少需要这么多的资源来解决问题。

平均情况(Average case):使用大 Θ 符号(Θ)表示算法的平均情况,描述了算法在所有可能输入情况下的平均表现。它给出了算法的期望性能。

通常情况下,我们更关注算法的上界和平均情况,因为它们提供了对算法性能的更全面评估。下界通常用于证明某个算法的最佳性能限制。

复杂度排序:Ο(1)<Ο(logn)<Ο(n)<Ο(nlogn)<Ο(n^2)Ο(n^3)<Ο(2^n)

算法复杂度的运算

我们通常以执行次数来匹配时间复杂度,看如下代码:

for (i = 0; i < n - 1; i++) {
        for (j = 0; j < n - i - 1; j++) {
            if (sorted_arr[j] > sorted_arr[j + 1]) {
                int temp = sorted_arr[j];
                sorted_arr[j] = sorted_arr[j + 1];
                sorted_arr[j + 1] = temp;
            }
        }
    }

算法中使用了两个嵌套的 for 循环,执行了 n^2 次循环操作,因此,我们可以说这个算法的时间复杂度是 O(n^2)

一般来说,在运算时,遵循以下规则:

(1)可以忽略加法常数

O(3n + 131) 相当于 O(3n)

(2)与最高次项相乘的常数可忽略

O(88n^3) 相当于 O(n^3)

(3) 最高次项的指数大的,函数随着 n 的增长,结果也会变得增长得更快

所以O(n^8) > O(n^4)

(4)判断一个算法的(时间)效率时,函数中常数和其他次要项常常可以忽略,而更应该关注主项(最高阶项)的阶数

例如:将O(3n^3+3n+1)的常数与次要项忽略,得到O(n^3)

顺序搜索算法

顺序搜索算法(Sequential Search Algorithm),也称为线性搜索算法,是一种简单直观的搜索方法。它逐个地检查待搜索的元素,直到找到目标元素或遍历完整个数据集。

示例如下:

#include <stdio.h>
int sequential_search(int arr[], int n, int target) {
    int i;
    for (i = 0; i < n; i++) {
        if (arr[i] == target) {
            return i;  // 返回目标元素的索引
        }
    }
    return -1;  // 目标元素未找到
}
int main() {
    int arr[] = {2, 5, 8, 10, 13, 6};
    int n = sizeof(arr) / sizeof(int);
    int target = 10;
    int result = sequential_search(arr, n, target);
    if (result != -1) 
    {
        printf("目标元素 %d 在数组中的索引为 %d\n", target, result);
    } 
    else 
    {
        printf("目标元素 %d 未找到\n", target);
    }
}

最好的情况即为:第一个元素就是要找的元素,常数时间O(1),最坏的情况即为:元素不在数组中,执行n次,线性时间O(n)。得到平均时间复杂度为最好情况与最坏情况对应的复杂度之和的一半。即o((1+n)/2),省略常数得到o(n)

二分搜索算法

二分搜索算法(Binary Search Algorithm),也称为折半搜索算法,是一种高效的搜索方法,它利用了已经排好序的数组的特点。它首先将待搜索区域缩小为一半,然后检查中间元素,如果目标元素等于中间元素,则找到目标;如果目标元素小于中间元素,则在左半部分继续搜索;如果目标元素大于中间元素,则在右半部分继续搜索。通过反复缩小搜索区域,最终可以找到目标元素或确定其不存在于数组中。

示例如下:

#include <stdio.h>
int binary_search(int arr[], int n, int target) {
    int left = 0;
    int right = n - 1;
    while (left <= right) {
        int mid = left + (right - left) / 2;
        if (arr[mid] == target) {
            return mid;  // 返回目标元素的索引
        } else if (arr[mid] < target) {
            left = mid + 1;  // 在右半部分继续搜索
        } else {
            right = mid - 1;  // 在左半部分继续搜索}
    }return -1;  // 目标元素未找到}

int main() {
    int arr[] = {2, 5, 6, 8, 10, 13};
    int n = sizeof(arr) / sizeof(int);
    int target = 8;int result = binary_search(arr, n, target);
    if (result != -1) 
    {
        printf("目标元素 %d 在数组中的索引为 %d\n", target, result);
    } 
    else 
    {
        printf("目标元素 %d 未找到\n", target);
    }
    return 0;
}

其原理是每次将搜索区间减半,因此需要进行logn次比较,所以时间复杂度是O(logn)。

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

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

相关文章

SpringCloud系列(一)| SpringCloud简介

上个系列中&#xff0c;我们已经介绍完了SpringBoot的用法&#xff0c;简单概述 springBoot Spring X, 就是对于Spring和其他技术的融合 进行了简化开发&#xff0c;所以x可以代表任何技术&#xff0c;比如 mybtis, mybatisPlus, redis.... 对于集成这些常用框架&#xff0c;…

Linux汇编语言编程-汇编语言

术语 Figure 3-13. 8086 Computer (Partial Model) reg 代表寄存器。 它可以是表 3.13 中列出的任何寄存器。 imm 代表立即数【immediate】&#xff08;可以理解为字面量&#xff0c;常量&#xff09;。 术语“立即数【immediate】”用于指代直接由十进制或十六进制表示形式给…

SQL排列组合

SQL排列组合 1、排列组合概述2、SQL排列组合2.1、排列2.2、组合3、SQL排列组合的应用1、排列组合概述 排列组合是针对离散数据常用的数据组织方法,本节将分别介绍排列、组合的SQL实现方法,并结合实例着重介绍通过组合对数据的处理 如何使用SQL实现排列与组合?本节将通过介绍…

【工具栏】(idea ) 英汉互换

目录 1. 将英文转换为汉字 2. 将中文转变英文 1. 将英文转换为汉字 file ---- settings 然后重启idea 2. 将中文转变英文 然后重启idea

后端对数据库查询的时间格式化

方式一&#xff1a; 在属性上加入注解&#xff0c;对日期进行格式化&#xff0c;如&#xff1a; JsonFormat(pattern "yyyy-MM-dd HH:mm:ss") private LocalDateTime updateTime;方式二&#xff1a; 在WebMvcConfiguration 中扩展Spring MVC的消息转换器&#xf…

系统架构达人亲授:多电商活动从容应对的顶级秘籍!

大家好&#xff0c;我是小米&#xff0c;一个热爱技术分享的小伙伴。最近我参加了一场社招面试&#xff0c;遇到了一道非常有趣的题目&#xff1a;在面对多个电商活动时&#xff0c;从架构上需要做到什么支持呢&#xff1f;今天我就来和大家分享一下我的思考和解答。 引言 随…

工业固体废物智能化综合管控平台

工业固体废物智能化综合管控平台&#xff0c;涵盖产废企业、运输企业、固废处置企 业等不同群体应用&#xff0c;根据不同群体设计不同的业务应用子系统功能&#xff0c;以及各个不 同群体的环保物联网平台子系统功能模块&#xff0c;同时具有移动端的应用APP。 建立产废企业端…

提升创造力:UI设计师不可错过的10个灵感网站

即时设计 即时设计是一个由国内团队开发的在线合作设计网站&#xff0c;帮助专业设计师找到设计灵感。其资源社区拥有丰富的平面设计材料和模板资源&#xff0c;如海报、平面广告、插图、网页设计、排版等&#xff0c;人们忍不住想尝试。同时&#xff0c;它还会不时更新设计资…

【MODBUS】Modbus是什么?

Modbus协议&#xff0c;从字面理解它包括Mod和Bus两部分&#xff0c;首先它是一种bus&#xff0c;即总线协议&#xff0c;和12C、SP|类似&#xff0c;总线就意味着有主机&#xff0c;有从机&#xff0c;这些设备在同一条总线上。 Modbus支持单主机&#xff0c;多个从机&#xf…

HPM5300系列--第一篇 命令行开发调试环境搭建

一、目的 在之前的博客中《HPM6750系列--第二篇 搭建Ubuntu开发环境》、 《HPM6750系列--第三篇 搭建MACOS编译和调试环境》我们介绍了HPM6750evkmini开发环境的搭建过程&#xff0c;由于HPM5300系列共用一套hpm-sdk&#xff0c;故HPM5300的开发调试环境的搭建过程基本和之前的…

最小范数法

最小范数法是一种全局算法&#xff0c;其主要思想是寻求接近于真实相位分布的解包裹相位&#xff0c;使解包裹相位的局部微分尽可能与测量相位微分相一致。这个过程在数学上等价于下列 P 阶方程组 到目前为止&#xff0c;最小范数法中应用最多&#xff0c;最成功的主要是最小二…

渗透测试框架——Cobalt Strike

渗透测试框架——Cobalt Strike Cobalt Strike是一款非常成熟的渗透测试框架。Cobalt Strike在3.0版本之前是基于Metasploit框架工作的&#xff0c;可以使用Metasploit的漏洞库。从3.0版本开始&#xff0c;Cobalt Strike不再使用Metasploit的漏洞库&#xff0c;成为一个独立的…

Gin之GORM 查询语句

前期工作可以看之前的&#xff08;连接数据库&#xff1b;以及确定要操作的库&#xff09; Gin之GORM 操作数据库&#xff08;MySQL&#xff09;-CSDN博客https://blog.csdn.net/m0_72264240/article/details/134948202?spm1001.2014.3001.5502这次我们操作gin库下的另外一个…

使用shell脚本给日志文件瘦身

一、前言 后台系统运行久了&#xff0c;日志文件的体积日渐增多&#xff0c;除了使用常用的日志框架如logback对日志进行按天打印、按大小分割等方式外&#xff0c;还可以使用shell命令来对大日志进行瘦身。 本篇使用sed指令来对文件进行操作&#xff0c;具体操作如下&#xf…

MySQL下载、安装、配置详细教程

目录 1 下载 2 安装 2.1执行安装命令&#xff1a; 2.2 编写配置文件 2.3查看默认mysql的密码&#xff1a; 2.4启动mysql服务 2.5 登录mysql&#xff0c;修改密码 3 系统环境变量配置 3.1 配置 3.2 测试 1 下载 官方网址&#xff1a; https://www.mysql.com/跳转到如…

Axure的动态面板

目录 动态面板 什么是Auxre动态模板 动态模板的步骤 应用场景 实战案例 轮播图 多功能登录界面 主界面左侧菜单栏 动态面板 什么是Auxre动态模板 动态面板是Axure中的一个重要功能&#xff0c;它允许用户创建可交互的页面&#xff0c;并模拟用户与页面的交互。通过添加元素…

如何学习Kubernetes,学习K8S入门教程

学习 Kubernetes&#xff08;K8s&#xff09;确实不容易 你的硬件资源有限时&#xff0c;不过别担心&#xff0c;我帮你理清思路&#xff0c;让你在学习 K8s 的路上更加从容。 1、资源限制下的学习方法 当硬件资源有限时&#xff0c;一个好的选择是使用云服务提供的免费层或者…

(反序列化)[HZNUCTF 2023 preliminary]ppppop

打开是空页面 抓包发现cookies有东西 O:4:"User":1:{s:7:"isAdmin";b:0;} 将零改为1&#xff0c;放包得到题目页面 <?php error_reporting(0); include(utils.php);class A {public $className;public $funcName;public $args;public function __dest…

小红书民宿文案怎么写?建议收藏

随着民宿市场的日益火爆&#xff0c;如何在众多民宿中脱颖而出&#xff0c;吸引更多租客入住&#xff0c;成为摆在每一位民宿业主面前的难题。一篇优质的小红书民宿文案&#xff0c;不仅能吸引潜在租客的关注&#xff0c;还能提高民宿的知名度。本文伯乐网络传媒将从八个方面教…

MATLAB 最小二乘空间直线拟合 (37)

MATLAB 最小二乘空间直线拟合 (37) 一、算法介绍二、算法实现1.代码一、算法介绍 对于空间中的这样一组点:大致呈直线分布,散乱分布在直线左右, 我们可采用最小二乘方法拟合直线,使用下面的代码可以得到图中的结果。(其中图片中的点解释和具体的实现代码如下所示) C++…