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

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

日常小例

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

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

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

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

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)来运行算法。

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


相关文章
|
29天前
|
机器学习/深度学习 人工智能 自然语言处理
【自然语言处理】TF-IDF算法在人工智能方面的应用,附带代码
TF-IDF算法在人工智能领域,特别是自然语言处理(NLP)和信息检索中,被广泛用于特征提取和文本表示。以下是一个使用Python的scikit-learn库实现TF-IDF算法的简单示例,并展示如何将其应用于文本数据。
186 65
|
30天前
|
存储 人工智能 自然语言处理
算法、系统和应用,三个视角全面读懂混合专家(MoE)
【8月更文挑战第17天】在AI领域,混合专家(MoE)模型以其独特结构成为推动大型语言模型发展的关键技术。MoE通过动态选择专家网络处理输入,实现条件计算。稀疏型MoE仅激活部分专家以减少计算负担;软MoE则加权合并专家输出提升模型稳定性。系统层面,MoE优化计算、通信与存储,利用并行化策略提高效率。在NLP、CV、推荐系统等领域展现强大应用潜力,但仍面临训练稳定性、可解释性等挑战。[论文链接: https://arxiv.org/pdf/2407.06204]
178 63
|
30天前
|
缓存 算法 Java
刷算法,你应该知道的队列经典应用
文章介绍了队列的基本特性和经典应用,包括如何用队列实现栈、使用优先级队列解决Top K问题,并通过LeetCode题目示例展示了队列在算法实现中的应用。
刷算法,你应该知道的队列经典应用
|
1月前
|
算法 Java 测试技术
算法分析(蛮力法与减治算法应用实验报告)
这篇文章是关于算法分析的实验报告,介绍了如何使用蛮力法解决背包问题,并通过伪代码和Java代码实现,同时分析了其时间效率;还介绍了基于减治法思想实现的二叉查找树的插入与查找,同样提供了伪代码、Java源代码实现和时间效率分析,最后展示了测试结果截图。
算法分析(蛮力法与减治算法应用实验报告)
|
14天前
|
机器学习/深度学习 算法 数据挖掘
R语言中的支持向量机(SVM)与K最近邻(KNN)算法实现与应用
【9月更文挑战第2天】无论是支持向量机还是K最近邻算法,都是机器学习中非常重要的分类算法。它们在R语言中的实现相对简单,但各有其优缺点和适用场景。在实际应用中,应根据数据的特性、任务的需求以及计算资源的限制来选择合适的算法。通过不断地实践和探索,我们可以更好地掌握这些算法并应用到实际的数据分析和机器学习任务中。
|
1月前
|
机器学习/深度学习 人工智能 算法
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
本文全面介绍了人工智能(AI)的基础知识、操作教程、算法实现及其在实际项目中的应用。首先,从AI的概念出发,解释了AI如何使机器具备学习、思考、决策和交流的能力,并列举了日常生活中的常见应用场景,如手机助手、推荐系统、自动驾驶等。接着,详细介绍了AI在提高效率、增强用户体验、促进技术创新和解决复杂问题等方面的显著作用,同时展望了AI的未来发展趋势,包括自我学习能力的提升、人机协作的增强、伦理法规的完善以及行业垂直化应用的拓展等...
140 3
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
|
18天前
|
算法 C++
A : DS串应用–KMP算法
这篇文章提供了KMP算法的C++实现,包括计算模式串的next数组和在主串中查找模式串位置的函数,用于演示KMP算法的基本应用。
|
21天前
|
缓存 算法 前端开发
深入理解缓存淘汰策略:LRU和LFU算法的解析与应用
【8月更文挑战第25天】在计算机科学领域,高效管理资源对于提升系统性能至关重要。内存缓存作为一种加速数据读取的有效方法,其管理策略直接影响整体性能。本文重点介绍两种常用的缓存淘汰算法:LRU(最近最少使用)和LFU(最不经常使用)。LRU算法依据数据最近是否被访问来进行淘汰决策;而LFU算法则根据数据的访问频率做出判断。这两种算法各有特点,适用于不同的应用场景。通过深入分析这两种算法的原理、实现方式及适用场景,本文旨在帮助开发者更好地理解缓存管理机制,从而在实际应用中作出更合理的选择,有效提升系统性能和用户体验。
46 1
|
29天前
|
机器学习/深度学习 人工智能 自然语言处理
【深度学习】探讨最新的深度学习算法、模型创新以及在图像识别、自然语言处理等领域的应用进展
深度学习作为人工智能领域的重要分支,近年来在算法、模型以及应用领域都取得了显著的进展。以下将探讨最新的深度学习算法与模型创新,以及它们在图像识别、自然语言处理(NLP)等领域的应用进展。
66 6
|
28天前
|
机器学习/深度学习 自然语言处理 负载均衡
揭秘混合专家(MoE)模型的神秘面纱:算法、系统和应用三大视角全面解析,带你领略深度学习领域的前沿技术!
【8月更文挑战第19天】在深度学习领域,混合专家(Mixture of Experts, MoE)模型通过整合多个小型专家网络的输出以实现高性能。从算法视角,MoE利用门控网络分配输入至专家网络,并通过组合机制集成输出。系统视角下,MoE需考虑并行化、通信开销及负载均衡等优化策略。在应用层面,MoE已成功应用于Google的BERT模型、Facebook的推荐系统及Microsoft的语音识别系统等多个场景。这是一种强有力的工具,能够解决复杂问题并提升效率。
41 2