这就是算法:日常生活中的算法应用

简介: 这就是算法:日常生活中的算法应用

日常小例

当我们一听到“算法”这个词,脑海里可能立刻浮现出数学公式和复杂计算的画面。

但事实上,算法并不总是那么高深莫测,很多算法其实是基于我们日常生活中随处可见的基本逻辑。

在深入讨论算法之前,我想先分享一个让人好奇的事实:你可能已经无意识地掌握了一些算法,并且在日常生活中自然而然地使用它们。

接下来,我会通过一些具体的例子来证明这一点。

1.找页码

在书本里,每个页面都有一个对应的页码。

而且每个页码都是按照一定的顺序编排的。

假设我们有这样一本书,他一共只有10页,我们要找到第7页。

我们通常会以下图的方式去查找。

image.png

  1. 翻开书本约一半的页数,查看该页的页码什么,假设本页为5.
  2. 由于在页码中 7位于5 之后,所以排除书本前半部分,查找范围缩小到后半部分。
  3. 不断重复步骤 1. 和 步骤 2. ,直至找到页码为7的页码为止。

看书找页码这个日常生活习惯,实际上就是著名的“二分查找”算法。

从数据结构的角度,我们可以把书本视为一个已排序的“数组”;

从算法的角度,我们可以将上述找页码的一系列操作看作“二分查找”。

2.整理钱包零钱

每个人钱包里面或多或少都有一些零钱,平时的时候估计都是杂乱的放着。

用的时候就一下拿出来。不方便。

所以我们习惯性的把零钱排序。使其从小到大的顺序排列。

实现步骤按下图所示。

image.png

  1. 将零钱划分为“有序”和“无序”两部分,并假设初始状态下最左 1 张零钱已经有序。
  2. 在无序部分抽出一张零钱,插入至有序部分的正确位置;完成后最左 2 张零钱已经有序。
  3. 不断循环步骤 2. ,每一轮将一张零钱从无序部分插入至有序部分,直至所有零钱都有序。

上述整理零钱的方法本质上是“插入排序”算法,它在处理小型数据集时非常高效。

许多编程语言的排序库函数中都有插入排序的身影。

这就是算法

通过上面两个简单的例子,我想你已经很明白算法到底是什么了。

我们下面再总结一下算法的理论。

算法定义

算法( algorithm )是在有限时间内解决特定问题的一组指令或操作步骤,它具有以下特性。

  1. 明确性:每一步都清晰明了,不含糊。
  2. 有穷性:步骤有限,不会无限循环下去。
  3. 输入:需要一些初始信息或数据来开始工作。
  4. 输出:完成步骤后,会得到一个结果或答案。
  5. 可行性:每一步都是可执行的,不会要求计算机做它做不到的事。

数据结构

数据结构,简单来说,就像是我们组织和存储信息的方式。

就像你可能会用书架来放书,用文件夹来整理文件一样,数据结构是计算机用来存储和组织数据的方法。

数据结构有几个关键点:

  1. 存储:数据结构决定了数据在计算机内存中存放的方式。
  2. 访问:它决定了我们如何快速地找到和使用数据。
  3. 操作:数据结构还决定了我们如何添加、删除或修改数据。
  4. 效率:不同的数据结构在执行这些操作时的效率不同。

数据结构与算法的关系

数据结构和算法就像是厨房里的食材和菜谱。

数据结构是食材,它决定了你可以用来做什么菜,以及这些食材如何存放在冰箱里。

算法则是菜谱,它告诉你如何使用这些食材来做出一道美味的菜肴。

他们的关系如下:

  1. 相互依赖:好的算法需要合适的数据结构来支持。就像好的菜谱需要合适的食材一样。如果你的数据结构不适合你的算法,那么算法的效率可能会大打折扣。
  2. 效率:数据结构的选择可以影响算法的效率。就像选择快速烹饪的食材可以节省时间一样,选择高效的数据结构可以让算法运行得更快。
  3. 功能:不同的数据结构有不同的功能,就像不同的食材有不同的用途。例如,数组适合快速访问元素,而链表适合快速插入和删除元素。
  4. 选择:在编程中,你可以根据需要选择不同的数据结构和算法。这就像是根据你想做的菜来选择食材和菜谱。
  5. 优化:通过优化数据结构和算法,你可以提高程序的性能。这就像是通过改进菜谱和烹饪技巧来提高菜肴的味道和制作效率。

总结

无论是简单的烹饪还是遥远的星际旅行,算法在解决问题的过程中扮演着不可或缺的角色。

自从计算机诞生以来,我们就能够利用编程技术将数据组织起来,存储在计算机的内存里。

同时,我们编写的代码可以指挥中央处理器(CPU)和图形处理器(GPU)来运行算法。

这使得我们能够将现实生活中的难题转移到计算机上,利用计算机的强大计算能力,以更加快速和高效的方法来处理各种棘手的问题。


相关文章
|
4月前
|
存储 监控 JavaScript
基于布隆过滤器的 Node.js 算法在局域网电脑桌面监控设备快速校验中的应用研究
本文探讨了布隆过滤器在局域网电脑桌面监控中的应用,分析其高效空间利用率、快速查询性能及动态扩容优势,并设计了基于MAC地址的校验模型,提供Node.js实现代码,适用于设备准入控制与重复数据过滤场景。
198 0
|
3月前
|
运维 监控 JavaScript
基于 Node.js 图结构的局域网设备拓扑分析算法在局域网内监控软件中的应用研究
本文探讨图结构在局域网监控系统中的应用,通过Node.js实现设备拓扑建模、路径分析与故障定位,提升网络可视化、可追溯性与运维效率,结合模拟实验验证其高效性与准确性。
237 3
|
3月前
|
机器学习/深度学习 资源调度 算法
遗传算法模型深度解析与实战应用
摘要 遗传算法(GA)作为一种受生物进化启发的优化算法,在复杂问题求解中展现出独特优势。本文系统介绍了GA的核心理论、实现细节和应用经验。算法通过模拟自然选择机制,利用选择、交叉、变异三大操作在解空间中进行全局搜索。与梯度下降等传统方法相比,GA不依赖目标函数的连续性或可微性,特别适合处理离散优化、多目标优化等复杂问题。文中详细阐述了染色体编码、适应度函数设计、遗传操作实现等关键技术,并提供了Python代码实现示例。实践表明,GA的成功应用关键在于平衡探索与开发,通过精心调参维持种群多样性同时确保收敛效率
|
3月前
|
机器学习/深度学习 边缘计算 人工智能
粒子群算法模型深度解析与实战应用
蒋星熠Jaxonic是一位深耕智能优化算法领域多年的技术探索者,专注于粒子群优化(PSO)算法的研究与应用。他深入剖析了PSO的数学模型、核心公式及实现方法,并通过大量实践验证了其在神经网络优化、工程设计等复杂问题上的卓越性能。本文全面展示了PSO的理论基础、改进策略与前沿发展方向,为读者提供了一份详尽的技术指南。
粒子群算法模型深度解析与实战应用
|
3月前
|
机器学习/深度学习 算法 安全
小场景大市场:猫狗识别算法在宠物智能设备中的应用
将猫狗识别算法应用于宠物智能设备,是AIoT领域的重要垂直场景。本文从核心技术、应用场景、挑战与趋势四个方面,全面解析这一融合算法、硬件与用户体验的系统工程。
|
5月前
|
机器学习/深度学习 人工智能 自然语言处理
深度学习模型、算法与应用的全方位解析
深度学习,作为人工智能(AI)的一个重要分支,已经在多个领域产生了革命性的影响。从图像识别到自然语言处理,从语音识别到自动驾驶,深度学习无处不在。本篇博客将深入探讨深度学习的模型、算法及其在各个领域的应用。
972 3
|
5月前
|
机器学习/深度学习 人工智能 算法
AI-Compass 强化学习模块:理论到实战完整RL技术生态,涵盖10+主流框架、多智能体算法、游戏AI与金融量化应用
AI-Compass 强化学习模块:理论到实战完整RL技术生态,涵盖10+主流框架、多智能体算法、游戏AI与金融量化应用
|
5月前
|
存储 监控 安全
企业上网监控系统中红黑树数据结构的 Python 算法实现与应用研究
企业上网监控系统需高效处理海量数据,传统数据结构存在性能瓶颈。红黑树通过自平衡机制,确保查找、插入、删除操作的时间复杂度稳定在 O(log n),适用于网络记录存储、设备信息维护及安全事件排序等场景。本文分析红黑树的理论基础、应用场景及 Python 实现,并探讨其在企业监控系统中的实践价值,提升系统性能与稳定性。
164 1
|
4月前
|
算法 数据可视化
matlab版本粒子群算法(PSO)在路径规划中的应用
matlab版本粒子群算法(PSO)在路径规划中的应用
|
5月前
|
存储 监控 算法
公司员工泄密防护体系中跳表数据结构及其 Go 语言算法的应用研究
在数字化办公中,企业面临员工泄密风险。本文探讨使用跳表(Skip List)数据结构优化泄密防护系统,提升敏感数据监测效率。跳表以其高效的动态数据处理能力,为企业信息安全管理提供了可靠技术支持。
133 0

热门文章

最新文章