什么是算法?一切皆算法

news/2024/9/21 8:22:52/文章来源:https://www.cnblogs.com/mangod/p/18385803

如果有人问我什么算法?我就一句话:算法就是对一类问题的最优求解路径。

1、计算机领域的算法概念

算法一直都是计算机领域非常重要的概念,具备极高的地位,各个公司对算法的考察也非常热衷。

我们只有在数学、计算机和人工智能领域会听到算法的概念,再加上似乎没人能讲清楚算法的概念。所以,一听到算法,很多人以为是个高深概念。

在计算机科学中,算法是指一个被定义好的、计算机可施行其指示的有限步骤或次序,常用于计算、数据处理和自动推理。

简单来说,算法就是一个定义明确的步骤集合,用来解决特定问题或执行特定任务。或者说算法是一种解决问题的方法,它通过一系列的步骤,逐步达到目标。

在编程中,算法被用来处理数据、执行计算、自动推理和做出决策。

我们常用的公共类算法很多,比如:

  • 排序算法:如快速排序、冒泡排序等,用于将数据按特定顺序排列。
  • 搜索算法:如二分查找,用于在数据集中找到特定元素。
  • 加密算法:如AES、RSA,用于数据加密和解密。
  • 路径规划算法:如Dijkstra算法,用于寻找最短路径。

2、算法只存在于计算机领域吗

我们基本只会在数学和计算机领域听过算法的概念,提到“算法”,很多人的第一反应是复杂的数学公式或计算机程序。那其他领域存在算法吗?

我的观点是,算法并不仅仅存在于科技领域,各个领域都存在算法。

为什么?因为算法是一个通用概念,它是一种解决问题的思维方式,它帮助我们理清思路,找到最优的解决方案。

算法说白了就是:对一类问题的最优求解路径

每个行业都存在各种各样的问题,每个问题都有对应的解决方法和步骤。有问题,有沉淀下来的解决路径,这不就是算法嘛。

所以每个行业都存在算法。我们不要把算法想的那么高深。

3、生活中的算法

比如在日常生活中,无论是农民在田间播种,还是建筑师设计大楼,甚至是我们在解决生活中的问题时,算法都无处不在。

农民种地的算法:农民要种出好的麦子,这个过程就是一个算法。首先,需要选择合适的种子,这是输入;然后,要根据天气、土壤和季节来决定何时播种,这相当于判断条件;最后,经过施肥、浇水、除草等一系列步骤,农民收获了粮食。这就是一个完整的算法过程。

建筑师的算法:建筑师设计一栋坚固的房子也是在执行一套算法。从选择建筑材料,到规划结构,再到每一个房间的布局,每一个步骤都是为了最终目标服务的。

日常生活中的算法:就连你早晨起床的过程也可以看作一个算法。你可能会在心里梳理一个步骤:起床、刷牙、洗脸、吃早餐、出门。这些看似简单的步骤,背后都有一个潜在的逻辑顺序,确保你能够顺利开始新的一天。

社会的算法:在社会中,规则和法律也是一种算法。它们帮助我们解决各种社会问题,维护秩序。比如,交通规则就是为了避免混乱和事故的一套算法;教育体系则是为了培养人才的一种算法。

程序员的算法:对于编程领域的算法,有两点说明:

  • 对于编程来说,编写高效的代码就是在执行算法。从需求分析到设计,再到编码、测试,每一步都是有目的、有方向的。
  • 为什么正常情况下我们不提“算法”俩字呢?因为常规的编码复杂度不高,在程序员的心目中低复杂度的流程和步骤还不足以称之为“算法”。但实际上简单的流程和步骤也是算法。

4、完结

算法就是对一类问题的最优求解路径,它存在于各行各业,无处不在。

本篇完结!欢迎 关注、加V(yclxiao)交流、全网可搜(程序员半支烟)

原文链接:https://mp.weixin.qq.com/s/s7pS_HUKjmfb-dNnHOyuBQ

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Adobe After Effects 2024 v24.6 (macOS, Windows) - 后期特效

Adobe After Effects 2024 v24.6 (macOS, Windows) - 后期特效Adobe After Effects 2024 v24.6 (macOS, Windows) - 后期特效 Acrobat、After Effects、Animate、Audition、Bridge、Character Animator、Dimension、Dreamweaver、Illustrator、InCopy、InDesign、Lightroom C…

在SimpleRAG中使用SiliconCloud快速测试Function Calling

Funcion Calling介绍 函数调用允许您将模型如gpt-4o与外部工具和系统连接起来。这对于许多事情都很有用,比如为AI助手赋能,或者在你的应用程序与模型之间建立深度集成。 如果您了解或者使用过Semantic Kernel可能会发现除了OpenAI支持Function Calling的模型之外,自动函数调…

Semantic Kernel/C#:一种通用的Function Calling方法,文末附经测试可用的大模型

Funcion Calling介绍 函数调用允许您将模型如gpt-4o与外部工具和系统连接起来。这对于许多事情都很有用,比如为AI助手赋能,或者在你的应用程序与模型之间建立深度集成。 如果您了解或者使用过Semantic Kernel可能会发现除了OpenAI支持Function Calling的模型之外,自动函数调…

折腾 Quickwit,Rust 编写的分布式搜索引擎 - 可观测性之日志管理

Quickwit 从底层构建,旨在 高效地索引非结构化数据,并在云存储上轻松搜索这些数据。 此外,Quickwit 开箱即支持 OpenTelemetry gRPC 和 HTTP(仅 protobuf)协议,并提供了一个 REST API,可以接收任何 JSON 格式的日志。 这让 Quickwit 成为了日志的理想选择!.https://qui…

读软件开发安全之道:概念、设计与实施12不受信任的输入

读软件开发安全之道:概念、设计与实施12不受信任的输入1. 不受信任的输入 1.1. 不受信任的输入可能是编写安全代码的开发人员最关心的问题1.1.1. 最好将其理解为输入系统中的所有不受信任的输入1.1.2. 来自受信任的代码的输入可以提供格式正确的数据1.2. 不受信任的输入是指那…

第12篇 window上验证mysql是否安装成功

1.命令提示符cmd窗口验证 1.1 键盘win+R打开命令提示符,输入cmd。 1.2 在电脑中找到安装好的MySQL的bin文件目录 。这是我的安装目录C:\Program Files\MySQL\MySQL Server 5.7\bin。1.3 在命令提示符中输入cd C:\Program Files\MySQL\MySQL Server 5.7\bin,再输入mysql -h loc…

南沙csp-j/s陈老师解题:1050:骑车与走路

​【题目描述】在清华校园里,没有自行车,上课办事会很不方便。但实际上。并非去办任何事情都是骑车快,因为骑车总要找车、开锁、停车、锁车等,这要耽误一些时间。假设找到自行车,开锁并骑上自行车的时间为27秒;停车锁车的时间为23秒;步行每秒行走1.2米,骑车每秒行走3.0米…

第11篇 MySql8.0 安装配置教程细讲

话不多说直接开干在安装之前, 先确定一下, 电脑上之前有没有安装MySQL ?或者看看有没有这个路径如果有, 请搜索网上的教程 1,停止服务 2,删除注册表 3,删除安装目录和data目录(如果有data目录的话) 弄完最好再重启系统 如果有删除残留可能导致后面安装出现问题 再开始阅读本教…

记录一次pip安装不了包(换源也不得行)

记录一次pip安装不了包(换源也不得行) 1.使用阿里云。安装不成功 (.venv) PS E:\python项目\路飞学院> pip install scrapy==2.5.1 -i http://mirrors.aliyun.com/pypi/simple/ Looking in indexes: http://mirrors.aliyun.com/pypi/simple/ WARNING: The repository lo…

net core中byte数组如何高效转换为16进制字符串

.NET Core 中把 byte[] 转换为 16 进制字符串的五种方法,简洁,灵活,高性能,哪个适合你?在 .NET Core 中,如何把 byte[] 转换为 16 进制字符串?你能想到哪些方法?什么方式性能最好?今天和大家分享几种转换方式。 往往在处理字符串性能问题时,首先应该想到的是怎么想办…

学习爬虫day30-瑞数eval入口定位及VM

“VM”表示的是Virtual Machine(虚拟机),这些文件通常表示由浏览器生成和执行的虚拟机脚本环境中的临时脚本。这些脚本并不是项目源代码的一部分,也不是实际存在的物理文件。 它们在浏览器的内存中创建并执行;通过eval函数或者new Function方法,Chrome浏览器会创建一个&q…

【待做】【文件包含】PHP伪协议

https://mp.weixin.qq.com/s/sxjf5TppUcjIsfk836BMhA 【文件包含】PHP伪协议原创 菜鸟小新PHP支持的伪协议 file:// — 访问本地文件系统 http:// — 访问 HTTP(s) 网址 ftp:// — 访问 FTP(s) URLs php:// — 访问各个输入/输出流(I/O streams) zlib:// — 压缩流 data:// —…