算法图解(1)

2024-09-03 01:36
文章标签 算法 图解

本文主要是介绍算法图解(1),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

配套代码:

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读取内存不是一个一个字节读取的,具体取多少个字节取决于硬件。如果对齐后一次寻址就可以找到数据,提高性能,但同样也会浪费内存资源,

这篇关于算法图解(1)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1131647

相关文章

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

poj 3974 and hdu 3068 最长回文串的O(n)解法(Manacher算法)

求一段字符串中的最长回文串。 因为数据量比较大,用原来的O(n^2)会爆。 小白上的O(n^2)解法代码:TLE啦~ #include<stdio.h>#include<string.h>const int Maxn = 1000000;char s[Maxn];int main(){char e[] = {"END"};while(scanf("%s", s) != EO

秋招最新大模型算法面试,熬夜都要肝完它

💥大家在面试大模型LLM这个板块的时候,不知道面试完会不会复盘、总结,做笔记的习惯,这份大模型算法岗面试八股笔记也帮助不少人拿到过offer ✨对于面试大模型算法工程师会有一定的帮助,都附有完整答案,熬夜也要看完,祝大家一臂之力 这份《大模型算法工程师面试题》已经上传CSDN,还有完整版的大模型 AI 学习资料,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

dp算法练习题【8】

不同二叉搜索树 96. 不同的二叉搜索树 给你一个整数 n ,求恰由 n 个节点组成且节点值从 1 到 n 互不相同的 二叉搜索树 有多少种?返回满足题意的二叉搜索树的种数。 示例 1: 输入:n = 3输出:5 示例 2: 输入:n = 1输出:1 class Solution {public int numTrees(int n) {int[] dp = new int