【算法设计与分析】(一)介绍算法与复杂度分析

news/2025/2/26 16:06:13

算法设计与分析】(一)介绍算法与复杂度分析

  • 前言
  • 一、什么是算法
  • 二、算法的抽象机制
  • 三、描述算法
  • 四、复杂度分析
      • 4.1 时间复杂度
      • 4.2 空间复杂度


前言

  • 从搜索引擎的高效检索,到推荐系统的个性化推荐,再到人工智能领域的复杂决策过程,算法都扮演着至关重要的角色

于每一个从事计算机相关工作或对编程有浓厚兴趣的人来说,深入理解算法设计与分析的原理和方法,不仅是提升编程技能的关键,更是解决实际问题、推动技术创新的必备能力。

  • 这篇博客将作为一个起点,带领大家逐步探索算法设计与分析的奇妙世界。我们将从基础的概念入手,为后续深入的学习和实践打下坚实的基础。

在这里插入图片描述

一、什么是算法

  • 算法,简单来说,就是为解决特定问题而设计的一系列明确且有限的步骤。

  • 例如,我们要计算两个数的和,设计一个算法可能包括输入两个数、执行加法运算、输出结果这几个步骤。

  • 程序则是算法在特定编程语言中的具体实现。以 C 语言为例,实现上述计算两数之和的程序如下:

#include <stdio.h>

int main() {
    float a, b, result;
    printf("请输入第一个数: ");
    scanf("%f", &a);
    printf("请输入第二个数: ");
    scanf("%f", &b);

    result = a + b;
    printf("两数之和为: %.2f\n", result);

    return 0;
}

在这段 C 语言代码中,我们首先包含了标准输入输出头文件stdio.h,以便使用printf和scanf函数进行输入输出操作。然后在main函数中,定义了三个变量a、b和result,分别用于存储输入的两个数和计算得到的和。通过scanf函数获取用户输入的两个数,执行加法运算后,使用printf函数将结果以保留两位小数的形式输出。

  • 可以看出,算法是程序的灵魂程序是算法的载体算法关注的是解决问题的逻辑和步骤,而程序则侧重于如何用具体的代码将算法实现出来。

在这里插入图片描述

二、算法的抽象机制

  • 算法的抽象机制是一种强大的工具,它允许我们将复杂的问题简化,提取出核心的逻辑和操作。

通过抽象,我们可以忽略问题中不必要的细节,专注于关键的步骤和关系。

  • 比如,在排序算法中,无论是冒泡排序、插入排序还是快速排序,它们都可以被抽象为对一组数据进行重新排列的过程我们可以将数据的比较和交换操作抽象出来,形成一个通用的排序框架。这种抽象不仅有助于我们理解不同排序算法的本质,还能方便我们在不同的场景中选择合适的算法

以冒泡排序为例,以下是 C 语言冒泡排序算法

#include <stdio.h>

// 交换两个整数的值
void swap(int *a, int *b) {
    int temp = *a;
    *a = *b;
    *b = temp;
}

// 冒泡排序函数
void bubbleSort(int arr[], int n) {
    int i, j;
    for (i = 0; i < n - 1; i++) {
        for (j = 0; j < n - i - 1; j++) {
            if (arr[j] > arr[j + 1]) {
                swap(&arr[j], &arr[j + 1]);
            }
        }
    }
}

int main() {
    int arr[] = { 64, 34, 25, 12, 22, 11, 90 };
    int n = sizeof(arr) / sizeof(arr[0]);

    bubbleSort(arr, n);

    printf("排序后的数组: ");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");

    return 0;
}

在上述代码中,swap函数用于交换两个整数的值,bubbleSort函数实现了冒泡排序的逻辑。通过多次比较相邻元素并交换顺序,最终将数组中的元素按照从小到大的顺序排列。

  • 抽象机制还可以帮助我们复用算法
  • 当我们设计出一个有效的算法解决某个问题后,通过抽象,我们可以将其应用到类似的问题中,提高开发效率。

在这里插入图片描述

三、描述算法

  • 为了清晰地表达算法,我们需要选择合适的描述方式。常见的描述算法的方式有自然语言、流程图、伪代码等
  • 自然语言是最容易理解的描述方式,它使用我们日常的语言来描述算法的步骤。
  • 例如,描述一个计算阶乘的算法:“首先输入一个整数 n,然后从 1 开始,依次乘以 2、3 直到 n,最后输出得到的结果。” 但自然语言描述可能存在歧义,不够精确。

  • 流程图则通过图形化的方式展示算法的流程。它使用各种图形符号(如矩形表示操作、菱形表示判断等)和箭头来表示算法的执行顺序。流程图直观易懂,有助于我们理清算法的逻辑结构。
    在这里插入图片描述
  • 伪代码是一种介于自然语言和编程语言之间的描述方式。它使用类似编程语言的语法结构,但更侧重于表达算法的逻辑,而不涉及具体的编程语言细节。例如,计算阶乘的伪代码可以写成:
input n
factorial = 1
for i from 1 to n
    factorial = factorial * i
end for
output factorial

以下是用 C 语言实现计算阶乘的代码

#include <stdio.h>

int main() {
    int n, i;
    long long factorial = 1;  // 使用long long类型以处理较大的阶乘结果

    printf("请输入一个整数: ");
    scanf("%d", &n);

    for (i = 1; i <= n; i++) {
        factorial *= i;
    }

    printf("%d 的阶乘为: %lld\n", n, factorial);

    return 0;
}

在这段 C 语言代码中,我们通过for循环从 1 到输入的整数n进行累乘,最终得到n的阶乘结果,并将其输出。

不同的描述方式各有优缺点,在实际应用中,我们可以根据具体情况选择合适的方式来描述算法

四、复杂度分析

  • 复杂度分析是算法设计与分析中非常重要的一个环节。它主要用于评估算法的效率,包括时间复杂度和空间复杂度。在深入探讨复杂度之前,我们先引入一个重要的概念:f(n)正函数
    在这里插入图片描述

4.1 时间复杂度

时间复杂度衡量的是算法执行所需的时间随着输入规模的增长而变化的趋势。我们通常使用大O符号( O O O)来表示时间复杂度

  • 大O符号的定义:设 f ( n ) f(n) f(n) g ( n ) g(n) g(n)是定义在正整数集上的正函数,如果存在正常数 c c c n 0 n_0 n0,使得当 n ≥ n 0 n \geq n_0 nn0时,有 f ( n ) ≤ c ⋅ g ( n ) f(n) \leq c \cdot g(n) f(n)cg(n),则称 f ( n ) f(n) f(n)在渐近意义下小于等于 g ( n ) g(n) g(n),记作 f ( n ) = O ( g ( n ) ) f(n) = O(g(n)) f(n)=O(g(n))

例如,对于一个算法,如果它的执行时间 T ( n ) T(n) T(n)可以表示为 T ( n ) = 3 n 2 + 2 n + 1 T(n) = 3n^2 + 2n + 1 T(n)=3n2+2n+1,我们可以找到 c = 4 c = 4 c=4 n 0 = 1 n_0 = 1 n0=1,当 n ≥ 1 n \geq 1 n1时, 3 n 2 + 2 n + 1 ≤ 4 n 2 3n^2 + 2n + 1 \leq 4n^2 3n2+2n+14n2,所以 T ( n ) = O ( n 2 ) T(n) = O(n^2) T(n)=O(n2)。这意味着随着输入规模 n n n的增大, n 2 n^2 n2这一项起主导作用,其他低阶项(如 2 n 2n 2n 1 1 1)对整体时间的影响越来越小,可以忽略不计。

常见的时间复杂度有:

  • O ( 1 ) O(1) O(1)(常数时间):算法的执行时间不随输入规模 n n n的变化而变化,例如访问数组中的一个固定位置的元素。
  • O ( log ⁡ n ) O(\log n) O(logn)(对数时间):常见于二分查找等算法,随着输入规模 n n n的增大,执行时间增长缓慢。
  • O ( n ) O(n) O(n)(线性时间):如顺序查找算法,执行时间与输入规模 n n n成正比。
  • O ( n log ⁡ n ) O(n \log n) O(nlogn):许多高效的排序算法(如归并排序、快速排序的平均情况)具有这种时间复杂度。
  • O ( n 2 ) O(n^2) O(n2)(平方时间):像冒泡排序、插入排序等简单排序算法的时间复杂度为 O ( n 2 ) O(n^2) O(n2),当输入规模较大时,算法的执行时间会显著增加。

4.2 空间复杂度

空间复杂度则关注算法在执行过程中所需的额外空间。同样使用大O符号来表示,即分析随着输入规模 n n n的增加,算法所需额外空间的变化趋势。

例如,一个算法在执行过程中,除了输入数据本身占用的空间外,只使用了固定数量的额外变量,无论输入规模 n n n如何变化,额外空间都不改变,那么该算法的空间复杂度就是 O ( 1 ) O(1) O(1)

如果一个算法需要创建一个大小与输入规模 n n n成正比的数组来存储中间结果,那么它的空间复杂度就是 O ( n ) O(n) O(n)

以之前的冒泡排序算法为例,其时间复杂度为 O ( n 2 ) O(n^2) O(n2),因为它有两层嵌套的循环,对于长度为 n n n的数组,总的比较和交换操作次数大约为 n ∗ ( n − 1 ) / 2 n * (n - 1) / 2 n(n1)/2,随着 n n n的增大,时间增长的趋势与 n n n的平方成正比。而其空间复杂度为 O ( 1 ) O(1) O(1),因为在排序过程中,除了输入的数组本身外,只使用了有限的额外变量(如循环变量 i i i j j j和用于交换的临时变量),额外空间的使用不随输入规模 n n n的变化而变化。

通过复杂度分析,我们可以在设计算法时选择更高效的方案,避免在实际应用中出现性能瓶颈。


非常感谢您的阅读,喜欢的话记得三连哦

在这里插入图片描述


http://www.niftyadmin.cn/n/5868918.html

相关文章

索提诺比率(Sortino Ratio):更精准的风险调整收益指标(中英双语)

索提诺比率&#xff08;Sortino Ratio&#xff09;&#xff1a;更精准的风险调整收益指标 &#x1f4c9;&#x1f4ca; &#x1f4cc; 什么是索提诺比率&#xff1f; 在投资分析中&#xff0c;我们通常使用 夏普比率&#xff08;Sharpe Ratio&#xff09; 来衡量风险调整后的…

无人机定点运输技术!

核心要点 定位与导航 GPS/北斗定位&#xff1a;依赖卫星系统实现高精度定位。 视觉导航&#xff1a;通过摄像头和计算机视觉技术识别环境。 惯性导航&#xff1a;利用加速度计和陀螺仪进行位置推算。 路径规划 避障算法&#xff1a;实时检测并避开障碍物。 动态路径调整…

蓝桥杯 Java B 组之回溯剪枝优化(N皇后、数独)

Day 4&#xff1a;回溯剪枝优化&#xff08;N皇后、数独&#xff09; &#x1f4d6; 一、回溯算法简介 回溯算法 是一种通过构造解空间树来进行问题求解的方法。其基本思想是 深度优先搜索&#xff08;DFS&#xff09;&#xff0c;通过递归遍历所有可能的解&#xff0c;并在每…

3D格式转换工具HOOPS Exchange在PMI处理中的关键作用与优势解析

在现代制造业的数字化进程中&#xff0c;产品和制造信息&#xff08;PMI&#xff09;扮演着至关重要的角色。PMI是指在CAD模型中所包含的用于明确制造和装配细节的各类注释与标记信息&#xff0c;涵盖了几何尺寸、公差、材料说明以及加工要求等关键要素。其能否实现有效传递&am…

Django笔记1_简介

备注&#xff1a;以下内容来自大模型回答。 Django功能简介 Django 是一个用 Python 编写的 web 框架。你可以把它想象成一个工具箱&#xff0c;里面有很多好用的工具&#xff0c;帮助你快速和轻松地创建网页应用程序。下面是一些 Django 的主要功能&#xff1a; 快速开发&am…

蓝桥杯试题:小明的彩灯(差分 前缀和)

一、题目描述 小明拥有 N 个彩灯&#xff0c;第 ii个彩灯的初始亮度为 ai​。 小明将进行 Q次操作&#xff0c;每次操作可选择一段区间&#xff0c;并使区间内彩灯的亮度 x&#xff08;x 可能为负数&#xff09;。 求 QQ次操作后每个彩灯的亮度&#xff08;若彩灯亮度为负数…

[C++][cmake]使用C++部署yolov12目标检测的tensorrt模型支持图片视频推理windows测试通过

最近悄悄出了yolov12框架&#xff0c;标志着目标检测又多了一个检测利器&#xff0c;于是尝试在windows下部署yolov12的tensorrt模型&#xff0c;并最终成功。 重要说明&#xff1a;安装环境视为最基础操作&#xff0c;博文不做环境具体步骤&#xff0c;可以百度查询对应安装步…

安全开发-环境选择

文章目录 个人心得虚拟机选择ubuntu 22.04python环境选择conda下载使用&#xff1a; 个人心得 在做开发时配置一个专门的环境可以使我们在开发中的效率显著提升&#xff0c;可以避免掉很多环境冲突的报错。尤其是python各种版本冲突&#xff0c;还有做渗透工具不要选择windows…