算法图解(1)

news2025/1/11 12:50:25

配套代码:

https://github.com/egonSchiele/grokking_algorithms?tab=readme-ov-fileicon-default.png?t=N7T8https://github.com/egonSchiele/grokking_algorithms?tab=readme-ov-file

理论

数据结构:组织和存储数据的方式,影响程序的性能和存储效率

算法:任何具有明确的步骤或规则的代码片段,用于旨在高效、准确地解决特定问题或执行某项任务。

设计模式:帮助开发者结构化和组织代码,提高代码的可维护性、可扩展性和复用性。

二分查找(查找算法)

原理:通过逐步将搜索范围缩小一半,快速定位目标元素的位置。

优点:高效,简单

缺点:通常仅适用于有序数组

时间:O(log n):因为每次查找都是上一次的一半,正好符合2的倍数

空间:

实例:给定排序好的数组,查找值为item的元素,在数组的什么索引位置

template <typename T>
int binary_search(const std::vector<T>& list, const int& item) {
    int low = 0;
    int high = list.size() - 1;

    while (low <= high) {
        int mid = (low + high) / 2;
        T guess = list[mid];

        if (guess == item) {
            return mid;
        }

        if (guess > item) {
            high = mid - 1;
        } else {
            low = mid + 1;
        }
    }

    return -1;
}

对数

幂:一个数被多次相同的数相乘的结果:底数a^指数b,a 自身乘以自身 b 次

对数:幂运算的逆运算:给定一个幂的结果,求底数需要多少次方才能得到这个结果

转换:logb(x) = y -> b^y = x

以 e 为底的对数,记作 ln⁡,  以 10 为底的对数,记作 log

时间复杂度

大O表示法:最坏情况运行时间: O(操作次数):指出了随着元素数量的增加,算法运行时间(并非以秒为单位,而是随着输入规模(通常用 n表示)趋向于无穷大时,算法运行时间的增长趋势)

引用
  1. O(1)常数时间,算法的运行时间不依赖于输入规模
  2. O(log n)对数时间,二分查找等分治算法
  3. O(n)线性时间,归并排序、快速排序
  4. O(n * log n)线性对数时间,速度较快,简单的线性查找或遍历
  5. O(n^2)平方时间,速度较慢,冒泡排序、选择排序。
  6. O(n^3)立方时间:通常是三重嵌套循环
  7. O(2^n)指数时间,暴力解法、某些递归算法
  8. O(n!)速度非常慢,暴力解法(旅行商问题)

空间复杂度

描述了算法在输入规模增加时,所需的存储空间的增长情况。考虑程序运行时占用内存的大小,而不是可执行文件的大小。

  • O(1)常数空间,只使用有限个变量,不额外申请空间
  • O(n)线性空间,需要额外数组或链表来存储输入数据。
  • O(n2)平方空间,需要一个二维数组来存储数据。

复杂表达式化简

  1. 去掉运行时间中的加法常数项 
  2. 去掉常数系数
  3. 只保留保留最高项,去掉数量级小一级的n 

递归与斐波那契数

递归 是指在定义或解决问题时,函数直接或间接地调用自己。递归可以简化代码层面的复杂度,而非时间空间复杂度

递归时间复杂度:递归的次数 * 每次递归中的操作次数。

阶乘:一个正整数的所有小于或等于该数的正整数的乘积

int function2(int x, int n) {
    if (n == 0) {
        return 1; 
    }
    return function2(x, n - 1) * x;
}

斐波那契数:其中每一项是前两项之和,F(0)=0,F(1)=1

int fibonacci(int i) {
       if(i <= 0) return 0;
       if(i == 1) return 1;
       return fibonacci(i-1) + fibonacci(i-2);
}

内存

  • 栈区(Stack) :由编译器自动分配释放,存放函数的参数值,局部变量的值等,其操作方式类似于数据结构中的栈。
  • 堆区(Heap) :一般由程序员分配释放,若程序员不释放,程序结束时可能由OS收回
  • 未初始化数据区(Uninitialized Data): 存放未初始化的全局变量和静态变量
  • 初始化数据区(Initialized Data):存放已经初始化的全局变量和静态变量
  • 程序代码区(Text):存放函数体的二进制代码

如何计算内存?根据数据类型占用的字节数

内存对齐:

经过内存对齐后,CPU访问内存的速度大大提升,因为CPU读取内存不是一个一个字节读取的,具体取多少个字节取决于硬件。如果对齐后一次寻址就可以找到数据,提高性能,但同样也会浪费内存资源,

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

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

相关文章

OpenHarmony使用ArkUI Inspector分析布局

● 摘要&#xff1a;视图的嵌套层次会影响应用的性能&#xff0c;开发者应该移除多余的嵌套层次&#xff0c;缩短组件刷新耗时。本文会介绍如何使用ArkUI Inspector工具分析布局&#xff0c;提示应用响应性能。 ● 关键字&#xff1a;列举本文相关的关键字&#xff1a;OpenHar…

Linux防火墙问题排查记录

问题描述 在业务当中&#xff0c;开通了防火墙&#xff0c;导致外部数据无法通过SFTP服务访问本机的服务&#xff0c;根据防火墙策略判断&#xff0c;应该是有一些IP没有被加进accept策略导致的&#xff0c;所以需要查看防火墙日志来追溯哪些IP被过滤掉了&#xff0c;只要放通…

开学了 需要考研的同学快看过来!考研倒计时你的鞭策神器!

开学了 需要考研的同学快看过来&#xff01;考研倒计时你的鞭策神器&#xff01; 2025年考研准备又要开始了&#xff0c;考试科目包括思想政治理论、管理类联考综合能力、外国语、业务课一、业务课二等。考研初试是每位考生迈向研究生阶段的重要一步&#xff0c;希望考生在考试…

python+requests 搭建接口自动化测试框架【超详细】

&#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 一、前言 Python是一种简单易学、功能强大的编程语言&#xff0c;广泛应用于各种软件开发和测试场景中。requests是Python中流行的HTTP库&#xff0c;支持发送…

windows下安装elasticSearch和kibana

下载es 下载地址官网 下载后是个压缩包(elasticsearch-8.15.0-windows-x86_64)&#xff0c;解压即可 启动 配置 改一下 /conf/jvm.options文件&#xff0c;最后加一行编码配置&#xff0c;这个是为了启动后防止控制台乱码 -Dfile.encodingGBK启动es 依赖jdk8环境&#xf…

Qt中的父窗口子窗口和父类子类的区别

好多人在开发初期&#xff0c;往往将父子窗口和父子类搅在一起容易搞混。 今天借着这篇文章给大家分辨一下。 C中我们常说子类继承自父类&#xff0c;子类具有父类所有的特性和功能。所以父类和子类是继承关系。 而子窗体和父窗体&#xff0c;不是继承关系&#xff0c;准确地讲…

安卓13拦截home功能 监听home键 禁用home键

总纲 android13 rom 开发总纲说明 目录 1.前言2.问题分析3.代码分析4.代码修改5.编译6.彩蛋1.前言 经常遇

数据结构与算法的代码实现(C++版)

数据结构与算法的代码实现&#xff08;C版&#xff09; 1. 线性表的顺序表示和实现1.1 线性表的初始化1.2 线性表的销毁1.3 线性表的清空1.4 线性表的长度1.5 判断线性表是否为空1.6 线性表的线性表取值1.7 线性表的顺序查找1.8 线性表的插入1.9 线性表的删除总结 2. 线性表的链…

EPLAN如何在插入设备的时候修改部件的数据?

EPLAN如何在插入设备的时候修改部件的数据&#xff1f; 默认情况下&#xff0c;插入部件的时候&#xff0c;部件的数据是无法更改的&#xff0c;那么如何设置在插入部件的时候对部件的数据进行修改呢&#xff1f; 具体可参考以下内容&#xff1a; 设置完成后&#xff0c;点击右…

QT实现简易记事本

QT的Qmainwindow实现简易记事本,不带有UI界面。 1、功能展示 1、编辑文件时&#xff0c;文件名左上角有个“*”,代表文件未保存 2、菜单栏有文件、编辑的选项 3、工具栏有保存、新建、打开、调节字体、调节颜色。 4、文件菜单中有&#xff0c;新建&#xff0c;保存、打开、…

【C语言从不挂科到高绩点】06-流程控制语句-循环语句

Hello&#xff01;彦祖们&#xff0c;俺又回来了&#xff01;&#xff01;&#xff01;&#xff0c;继续给大家分享 《C语言从不挂科到高绩点》课程 本套课程将会从0基础讲解C语言核心技术&#xff0c;适合人群&#xff1a; 大学中开设了C语言课程的同学想要专升本或者考研的…

2024测试开发必知必会:Pytest框架实战!

应用场景&#xff1a; pytest 框架可以解决我们多个测试脚本一起执行的问题。 它提供了测试用例的详细失败信息&#xff0c;使得开发者可以快速准确地改正问题。它兼容最新版本的 Python。它还兼容 unittest、doctest 和 nose&#xff0c;开箱即用。接下来我们详细了解下pyte…

LLM与知识图谱

重磅推荐专栏: 《大模型AIGC》 《课程大纲》 《知识星球》 本专栏致力于探索和讨论当今最前沿的技术趋势和应用领域,包括但不限于ChatGPT和Stable Diffusion等。我们将深入研究大型模型的开发和应用,以及与之相关的人工智能生成内容(AIGC)技术。通过深入的技术解析和实践经…

昆仑山矿泉水《大湾区旅行者》正式开机,携手共赴一场净化心灵之旅

在这个快节奏的时代&#xff0c;我们总在寻找一片能让心灵得以栖息的地方。今年&#xff0c;昆仑山矿泉水与深圳卫视再度携手&#xff0c;推出充满人文温情与自然探索的慢生活旅行综艺《大湾区旅行者》&#xff0c;目前已于8月29日开机启航。本次旅行&#xff0c;昆仑山矿泉水与…

废品回收小程序,从传统到现代化的回收模式

在数字化发展的当下&#xff0c;废品回收行业也进行了更新换代&#xff0c;由传统“喊卖”&#xff0c;到目前的线上回收&#xff0c;将互联网小程序与废品回收相结合&#xff0c;打造一个线上回收模式&#xff0c;让大众可以直接通过手机进行回收。小程序的出现不仅解决了传统…

四层神经网络,反向传播计算过程;四层神经网络中:y的函数公式是什么

目录 四层神经网络,反向传播计算过程 网络结构 前向传播 损失函数 反向传播 1. 计算输出层到隐藏层 2 的梯度 2. 计算隐藏层 2 到隐藏层 1 的梯度 3. 计算输入层到隐藏层 1 的梯度 梯度下降更新 四层神经网络,反向传播计算过程 在四层神经网络中,使用均方差损失函数…

H264结构及RTP封装

H264是一种针对视频的压缩编码方式。 一、压缩方法 H264主要基于以下几种方法&#xff0c;将数据进行压缩&#xff1a; 1.帧内预测压缩&#xff1a;解决空间域数据冗余的问题 2.帧间预测压缩&#xff1a;&#xff08;运动估计与补偿&#xff09;解决时间域数据冗余的问题 3…

项目实训:创建一张贺卡以及一只盒子——WEB开发系列27

以下是两道关于基础 CSS 盒模型和其他盒子相关特性的练习题&#xff0c;适合测试对这些概念的掌握程度&#xff0c;通过实际的设计任务来深入理解这些概念。 练习题 1: 设计一张中秋节海报贺卡 任务描述 制作一张精美的中秋节海报贺卡&#xff0c;用于庆祝这个传统节日。你的…

visual studio 2022更新以后,之前的有些工程编译出错,升级到Visual studio Enterprise 2022 Preview解决

系列文章目录 文章目录 系列文章目录前言一、解决方法 前言 今天遇到一个问题&#xff1a;visual studio 2022升级成预览版以后&#xff0c;之前的有些工程编译出错。首先代码、项目设置都没有改变&#xff0c;只是更新了visual studio 2022。 在编译工程时&#xff0c;编译器…

Source-code-of-charging-云快充协议1.5+互联互通协议+新能源汽车充电桩系统

介绍 SpringBoot 框架&#xff0c;充电桩平台充电桩系统充电平台充电桩互联互通协议云快充协议1.5-1.6协议新能源汽车二轮车公交车二轮车充电-四轮车充电充电源代码充电平台源码Java源码 软件架构 软件功能 小程序端&#xff1a;城市切换、附近电站、电桩详情页、扫码充电、…