当前位置:首页 > 芯闻号 > 充电吧
[导读] 当你使用搜索引擎(例如Google Chrome、Mozilla Firefox等)的时候,后台发生了什么?当你询问虚拟助手(例如Alexa、Google助手或Siri)的时候,后台发生了什么?它

当你使用搜索引擎(例如Google Chrome、Mozilla Firefox等)的时候,后台发生了什么?当你询问虚拟助手(例如Alexa、Google助手或Siri)的时候,后台发生了什么?它们怎么会知道答案?为何它们会显示正确答案?所有这些都要感谢算法。

每当你使用手机、计算机、笔记本电脑或计算器时,其实都在使用算法。

那么,什么是算法?

如果你想做数学运算,比如说两个数字相乘(不使用任何电子设备),那么你需要在纸上做乘法。你按照一定的规则获得正确的答案。你也可以使用耗时更少的方法来做计算。这就是算法。

算法是为执行特定的任务而设计的一组指令。

有些算法很简单,而有些则非常复杂,具体取决于你要实现的目标。

算法的历史

了解历史总是有好处,因为历史可以帮助你更好地理解主题,并了解何时使用这些知识。

“算法”一词源自九世纪波斯数学家Muhammad Ibn Musa Al-Khwarizmi(代数之父),拉丁语为Algoritmi。最初算法被称为Algorismus。15世纪后期,改名为Algorithmus(源自希腊语Arithmetic)。现代英语中的Algorithm一词是于19世纪引入的。

算法在中国古代文献中称为“术”,最早出现在《周髀算经》、《九章算术》。特别是《九章算术》,给出四则运算、最大公约数、最小公倍数、开平方根、开立方根、求素数的埃拉托斯特尼筛法,线性方程组求解的算法。三国时代的刘徽给出求圆周率的算法:刘徽割圆术。


1842年,Ada Lovelace首次编写了计算引擎的算法,因此许多人常常称她为世界上第一位计算机程序员。她为巴贝奇分析机(自动计算的机械计算机)编写了求解伯努利微分方程的算法(巴贝奇分析机由计算机之父Charles Babbage开发)。


1936年,Alan Turing的图灵机首次提出了第一个以现代形式表示的算法。


如何表达算法?

表达算法的方法多种多样,例如自然语言、伪代码、流程图、编程语言、动态图表、控制表等等。

使用自然语言表达算法不够清晰,因此很少用于复杂或技术算法。伪代码、流程图、drakon图和控制表是表达算法的结构化方法,因为与自然语言相比,它们可以避免许多歧义。编程语言旨在以可由计算机执行的形式表达算法。

在计算机系统中,算法是由软件开发人员以他们选择的任何编程语言编写的逻辑。但是,在设计算法时,我们需要记住一些规则。其中包括:

输入:算法至少需要一个或多个输入值。如果没有给出输入,那么算法将产生什么输出呢? 输出:算法至少应产生一个输出。如果没有产生任何结果,则无需设计算法。 效率:算法应该保证高效利用计算和内存资源。产生的输出应该又正确又快。 简单性:算法不应过于复杂。 可扩展性:算法必须能够在不更改核心逻辑的情况下进行扩展。 有限性:算法必须在有限步骤后终止。假设输入错误的情况下,算法在第一步就终止,我们将永远无法得知算法有什么问题。而且,算法也不能陷入无限循环。 不依赖于编程语言:算法必须与语言无关,也就是说,它必须是可以用任何一种语言都可以实现的简单指令,但是无论任何语言,输出都应当相同。

下面,我们来构建一个简单的算法:两个数字的加法(且满足上述要求)。

第1步:开始; 第2步:声明变量num1,num2和sum; 第3步:读取值num1和num2; 第4步:将num1和num2相加,然后将值赋给sum。 第5步:显示和; 第6步:停止。

下面,为了测试这个算法,我们使用一种编程语言来实现它,我选择用Java语言来实现,你可以任意选择其他语言。

public class Addition { public static void main(String[] args) { int num1, num2, sum; Scanner sc = new Scanner(System.in); System.out.println(“Enter First Number: “); num1 = sc.nextInt; System.out.println(“Enter Second Number: “); num2 = sc.nextInt; sc.close; sum = num1 + num2; System.out.println(“Sum of two numbers: “+sum); } }

输出如下:

我们的算法运作良好,且满足上述要求。

算法必须高效。算法的效率取决于时间和空间。一个好的算法占用的时间更少,占用的空间也更少,我们无法时刻兼顾两者。如果减少时间,则则空间可能会增加,反之亦然。因此,我们必须妥协一方。算法的空间复杂度表示算法运行时占用或需要的总空间。时间复杂度是指算法花完成任务所需的操作数。以最少操作数执行任务的算法就是最有效的算法。此外,算法花费的时间还取决于计算机的计算速度,但是在我们考虑算法的效率率时,通常不会考虑这些外部因素。衡量算法效率的一种方法是测量算法在不同输入下找到答案所需的操作次数。


算法的种类

递归算法:通过重复将问题分解为同类的子问题而解决问题。 分治算法:把一个复杂的问题分成两个或更多的相同或相似的子问题,直到最后子问题可以简单的直接求解,原问题的解即子问题的解的合并。 动态规划算法(又名动态优化算法):记住过去的结果,以备将来使用。与分治算法相似,这种算法可以将复杂的问题分解相对简单的子问题,然后将解决方案保存起来,以便下次需要同一个子问题解之时直接使用,而无需再次重新计算。 贪婪算法:在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望得出结果是最好或最优的算法。该算法不能保证最终获得最佳解决方案。 暴力算法:简单明了,尝试所有的可能性,直到找到满意的解决方案为止。 回溯算法:尝试分步地去解决一个问题。如果发现其中某一步的解决方案失败,则后退一步或几步,重新开始寻找解决方案。


如今,几乎每个领域都使用算法,例如数据科学、机器学习、农业、科学、运输等。算法是每个应用程序(Google Chrome与Mozilla Firefox、Uber与Ola)最大的不同之处,例如Google Chrome和Mozilla Firefox都是搜索引擎应用程序,它们提供相同的结果,但是结果的顺序有所不同,这是因为二者使用了不同的排序算法。Google的排序算法与Firefox不同。

算法无处不在,并将继续传播,算法让我们的生活更加轻松,但我们还需要考虑一些问题,例如,

当有一天数据和预测模型统治世界,那么我们就会丧失人性和判断力。 随着更智能、更高效的算法逐步取代许多的人类活动,失业人数将上升。

21世纪,算法就像魔术一样,我们可以解释其背后的原理以及如何创建网络等,却无法机械地解释为什么这些算法会产生特定的输出。而这仅仅是个开始。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭