56星座屋
当前位置: 首页 星座百科

怎么样才能掌握算法(避不开的算法如何吃透)

时间:2023-07-07 作者: 小编 阅读量: 2 栏目名: 星座百科

算法是为执行特定的任务而设计的一组指令。最初算法被称为Algorismus。编程语言旨在以可由计算机执行的形式表达算法。在计算机系统中,算法是由软件开发人员以他们选择的任何编程语言编写的逻辑。不依赖于编程语言:算法必须与语言无关,也就是说,它必须是可以用任何一种语言都可以实现的简单指令,但是无论任何语言,输出都应当相同。

作者 | Alekya Ragipally

译者 | 弯月,编辑 | 屠敏

题图 | 自东方 IC

出品 | AI科技大本营(ID:rgznai100)

当你使用搜索引擎(例如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 = num1num2;

System.out.println(“Sum of two numbers: “ sum);

}

}

输出如下:

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

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

算法的种类

  • 递归算法:通过重复将问题分解为同类的子问题而解决问题。

  • 分治算法:把一个复杂的问题分成两个或更多的相同或相似的子问题,直到最后子问题可以简单的直接求解,原问题的解即子问题的解的合并。

  • 动态规划算法(又名动态优化算法):记住过去的结果,以备将来使用。与分治算法相似,这种算法可以将复杂的问题分解相对简单的子问题,然后将解决方案保存起来,以便下次需要同一个子问题解之时直接使用,而无需再次重新计算。

  • 贪婪算法:在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望得出结果是最好或最优的算法。该算法不能保证最终获得最佳解决方案。

  • 暴力算法:简单明了,尝试所有的可能性,直到找到满意的解决方案为止。

  • 回溯算法:尝试分步地去解决一个问题。如果发现其中某一步的解决方案失败,则后退一步或几步,重新开始寻找解决方案。

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

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

  • 当有一天数据和预测模型统治世界,那么我们就会丧失人性和判断力。

  • 随着更智能、更高效的算法逐步取代许多的人类活动,失业人数将上升。

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

原文链接:

https://medium.com/@alekya3/what-is-an-algorithm-everything-you-need-to-know-about-algorithms-79bb99cb0c11

  • 利用 AssemblyAI 在 PyTorch 中建立端到端的语音识别模型

  • 京东姚霆:推理能力,正是多模态技术未来亟需突破的瓶颈

  • 性能超越最新序列推荐模型,华为诺亚方舟提出记忆增强的图神经网络

  • FPGA 无解漏洞 “StarBleed”轰动一时,今天来扒一下技术细节!
  • 真惨!连各大编程语言都摆起地摊了

  • 发送0.55 ETH花费近260万美元!这笔神秘交易引发大猜想
    推荐阅读
  • 形成酸雨的主要气体是什么(形成酸雨的主要气体)

    以下内容大家不妨参考一二希望能帮到您!形成酸雨的主要气体是什么酸雨是指PH小于5.6的雨雪或其他形式的降水,形成的主要气体有二氧化硫、三氧化硫、硫化氢、二氧化氮。酸雨主要是人为的向大气中排放大量酸性物质所造成的。酸雨又分硝酸型酸雨和硫酸型酸雨。

  • 木棉花的花语是什么(木棉花的意义)

    接下来我们就一起去了解一下吧!珍惜眼前的幸福,珍惜身边的人给他们快乐与幸福。它的花期通常在3月或者4月份,在这一段时间盛开,而传说中四月的第十一天,是木棉花盛开的日子,所以4月11被定为木棉花的日子。

  • 炒凉皮不碎技巧(炒凉皮不碎有什么技巧)

    以下内容大家不妨参考一二希望能帮到您!炒凉皮不碎技巧炒凉皮不碎技巧:就是在做凉皮时不能炒太久,变软会失去筋度。胡萝卜切丝,蒜薹切段,葱切花,猪肉切丝,大蒜拍扁。成品凉皮一张张卷起切粗条,抖散备用。生抽,白糖,盐,鸡精,醋,胡椒粉调成汁备用。热锅倒适量食用油烧热加入大蒜,肉丝翻炒至金黄,加入胡萝卜丝和蒜薹炒熟,凉皮翻炒均匀后随即淋入调好的汁儿翻炒均匀。

  • 近几年灭绝的鱼(瞭望在长江源寻鱼)

    长江被誉为我国淡水渔业的摇篮、鱼类基因的宝库。据青海省渔业部门统计,长江流域青海段分布有土著鱼类21种。因此,严格意义上长江源的关键鱼类指的是裂腹鱼中的小头裸裂尻鱼。2019年,李伟带领团队参加长江源科考时,将小头裸裂尻鱼列为长江源鱼类研究的代表对象。2019年4月,科考小组五个人,两台车,开始了沿河寻觅之旅。“全球平均气温上升已是科学界的共识,位于青藏高原的长江源是全球气候变化的敏感区。”科考发现,江源地区

  • 鹧鸪在什么时候季节鸣叫(鹧鸪的孵化期有多长)

    鹧鸪在什么时候季节鸣叫鹧鸪一般会在繁殖季节鸣叫,繁殖期为3-6月,3-4月间开始求偶交配。求偶期间鸣叫更为频繁,常在山岩、树桩、灌木或乔木枝上鸣叫,尤以黎明和黄昏时更甚,往往是一鸟先鸣叫,其他雄鸟一起跟随,此起彼伏。鹧鸪的孵化期在21天左右,雏鸟出壳后不久即可跟随亲鸟活动。鹧鸪的繁殖期为每年的3-6月,3-4月间开始求偶交配,每窝产卵3-6枚,多时可达8枚,卵为椭圆形或梨形,颜色为淡皮黄色至黄褐色。

  • 秋天的诗词(这些都是关于秋天的诗句)

    迢迢新秋夕,亭亭月将圆《戊申岁六月中遇火》,今天小编就来说说关于秋天的诗词?《戊申岁六月中遇火》自古逢秋悲寂寥,我言秋日胜春朝。《秋词》是处红衰翠减,苒苒物华休。惟有长江水,无语东流。宋·柳永《八声甘州》落时西风时候,人共青山都瘦。《昭君怨》雨色秋来寒,风严清江爽。《酬裴侍御对雨感时见赠》秋声万户竹,寒色五陵松。唐·李颀《望秦川》秋色无远近,出门尽寒山。宋·苏轼《九日次韵王巩》

  • 广州有几种车牌(广州车牌你有吗)

    在广州的普通上班族,有房贷还想拥有一辆车,已经不容易了。但有车想让个广州牌,那更是难上加难,再加之限行,参与摇号,竞价的人是越来越多,那中标的机会更是渺茫了!截止日期是8日24时止。9月拟配置的中小客车增量指标共16313个,是这样分配的:1.以摇号方式向单位和个人配置节能车增量指标7285个,其中,单位指标100个,个人指标7185个。

  • qq注销账号有哪几个步骤(QQ将开注销帐号功能)

    1999年2月10日,一个名为OICQ、只有几百K的软件正式上线。当时,腾讯方面表示,这是QQ团队对帐号注销功能的灰度测试。网友截图出于安全考虑,也有网友表示支持有人说,QQ不推出注销服务有自己的考虑,这是为了防止用户QQ密码被他人知道后恶意注销,给用户带来无法挽回的损失。腾讯2018年第三季度财报显示,QQ智能终端月活跃账户同比增长6.9%至6.979亿。

  • 高跟鞋不合脚怎么办(穿高跟鞋不合脚怎么办)

    4、合理利用袜子,如果不喜欢垫各种鞋垫的朋友,可以穿一双船袜,再穿高跟鞋,那样既不影响穿着效果,也不影响美观,也是比较简单和实用的方法。

  • 年四旺名字打分104分 年四旺事迹

    文章目录:一、年四旺相关名字打分113二、年四旺相关名字评分115三、年四旺相关名字推荐四、年四旺相关名字大全五、其他人还看了一、年四旺相关名字打分113年灯石志明年橘纪红兵武尊道后书法孔多塞年贷款孙敬媛年立秋里蓝业珍冯景华年见朱诗词林于思冯桂年粤日林格孟昭毅年家薛邑马布鱼鲁初雪苏沫沫卜庆中年上年掌柜秦源达刘登龙严学锋国韵酒年线高成江裘梦年维泗红沙日年周王克斌王翔千毛淑红龙威信李万和年神范小慧王大