避不开的算法,如何吃透?
作者 | 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 = num1 + num2;
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万美元!这笔神秘交易引发大猜想
你点的每个“在看”,我都认真当成了AI
相关文章:

CentOS 6.4下PXE+Kickstart无人值守安装操作系统
一、简介1.1 什么是PXEPXE(Pre-boot Execution Environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持工作站通过网络从远端服务器下载映像,并由此支持通过网络启动操作系统,在…

Asp.NET中常用的一些优化性能的方法
ASP.NET 的缓存机制相比ASP有很大的改进,本文档除对常用优化方法进行总结介绍外,强调了如何使用ASP.NET的缓存来获得最佳性能。1:不要使用不必要的session 和ASP中一样,在不必要的时候不要使用Session。可以针对整个应用程序或者页…
不信你看!这次Python和AI真的玩儿大了!!
这是一个很难让人心平气和的年代。不少人都想学 AI,总担心自己学不会,学不懂,或者学的课不是只教Python,就是缺少项目实战。最终都是浅尝辄止,不了了之!我每天在公众号后台收到上千条类似的留言:…

【引用】在Eclipse中将java Project转换成Dynamic Web Project
编辑工程的.project文件: 添加 <nature>org.eclipse.wst.common.project.facet.core.nature</nature> <nature>org.eclipse.wst.common.modulecore.ModuleCoreNature</nature> <nature>org.eclipse.jem.workbench.JavaEMFNature<…

mysql之字符编码问题
mysql编码分为服务端编码和客户端编码两大类字段编码, 表编码, 数据库编码这些编码都属于服务端编码,服务端编码决定你可以存哪些字符以及这些字符要哪种规则排序.字段编码优先级最高. 你插入用什么码属于客户端编码, 你用什么客户端编码都无所谓,只要插入前加个命令set names …
关于GCN,我有三种写法
作者 | 阿泽来源 | 阿泽的学习笔记(ID: aze_learning)本篇文章主要基于 DGL 框架用三种不同的方式来实现图卷积神经网络。DGL简介DGL(Deep Graph Library)框架是由纽约大学和 AWS 工程师共同开发的开源框架,旨在为大家…

CentOS5快速搭建vsftp服务
既然强调快速, 我们就马上开始,环境是centos5安装vsftpd,用了半天做了测试与修改,终于完成。 第一步:安装vsftpd,在终端允许 # yum -y install vsftpd 没什么问题就直接安装好啦 第二步:编辑vsftpd的配置…

我和freelancer不得不说的故事5 --- 心理落差
我和freelancer不得不说的故事5 --- 心理落差 我下海之前所在的外企,是一家顶级知名IT企业,其SAP咨询服务业务规模和影响都很大,是SAP咨询界五大咨询公司之一。我从07年加入这家公司,到辞职下海,在这家公司工作8年半。…
一起谈.NET技术,asp.net控件开发基础(18)
本篇继续上篇的讨论,可能大家已经在使用asp.net2.0了,DataSource属性不再使用,而是跟数据源控件搭配使用.现在讨论的绑定技术都是基于1.1版本,先熟悉一下,本质上是一样的,这样一步步的学习.对以后绝对有帮助.因为当你使用数据源控件,只需要设置一个DataSourceID,方便…

使用sqlserver来存放和取得session
asp.net 提供了三种存放 session的方式。 1 InProc 2 State Server 3 SQL Server 第一种是我们经常用的,第2中就是使用一个名为 state server 的机器用它的内存来存放其他机器的session 状态,其实,我们还可以在 sql server 里面来存放和取…

五项挑战获四项第一,地平线霸榜Waymo自动驾驶算法挑战赛
美国当地时间6月15日,Alphabet(Google母公司)旗下的自动驾驶公司Waymo在CVPR 2020自动驾驶Workshop上揭晓Waymo开放数据集挑战赛的结果,边缘AI芯片企业地平线斩获5项挑战中的4项全球第一。 本次挑战赛,Waymo开放了其自…

SSO单点登录基于CAS架构封装 Memcached 实例
2019独角兽企业重金招聘Python工程师标准>>> SSO认证中心是CAS整个应用架构的一个极其重要的关键点,必须满足如下两点要求: 1.高可用,不允许程序发生故障。如果认证中心发生故障,整个应用群将无法登录,导致…

HTMLButton控件下的Confirm()
作者:未知 请作者速与本人联系一、前言在ASP.NET中大部分如删除等一些动作为了友好都为添加confirm()来弹出消息框进行提示,但是HTML控件和WEB控件是否使用的方法是一样的呢?二、方法A. System.Web.UI.WebControls.Button控件现在一般都是这样在Page_…
Python 还能实现哪些 AI 游戏?附上代码一起来一把!
作者 | 李秋键责编 | Carol头图 | CSDN 付费下载自视觉中国人工智能作为当前热门在我们生活中得到了广泛应用,尤其是在智能游戏方面,有的已经达到了可以和职业选手匹敌的效果。而DQN算法作为智能游戏的经典选择算法,其主要是通过奖励惩罚机制…

一起谈.NET技术,专访微软MVP衣明志:走进ASP.NET MVC 2框架开发
日前微软已经发布ASP.NET MVC 2框架RC版,究竟这次RC版本的发布对于WEB开发者带来怎样的改变?以及未来ASP.NET MVC 2正式版还会有哪些改进?带着这样的问题,我们51CTO记者彭凡专门采访了微软MVP衣明志老师。ASP.NET MVC是微软官方提…

Entity Framework:Code-First Tutorial开篇
这个系列文章是关于Entity Framework Code-First的英文系列文章,内容不错,每篇一个主题知识点介绍,特转载过来 原文地址:http://www.entityframeworktutorial.net/code-first/entity-framework-code-first.aspx转载于:https://www…

Android开发者指南(22) —— Accessing Resources
前言 本章内容为Android开发者指南的Framework Topics/Application Resources/Accessing Resources章节,译为"资源调用",版本为Android 3.2 r1,翻译来自:"CodeGuy",欢迎访问他的博客ÿ…

如何快速实现HTML编辑器.NET组件
作者:未知 请作者速与本人联系得到“素材”首先我们需要得到一个HTML编辑器的原始代码,网上有不少这类的编辑器,如大名鼎鼎的RichTextBox,为了避免版权纠纷,以我所做得为例(暂名:UltraTextBox…

罗永浩力荐,丁磊豪送的学习神器:手机查词真不如这支AI词典笔?
销量确实称得上火爆。尽管999元的直播优惠价价格并不低,但这支有道词典笔专业版在快手直播间还是经历了返场,最终20000多台一抢而空。 为这款产品站台的正是网易CEO丁磊,6月11日是他网上卖货的首秀,不过更重要的是,那天…

Thinking in java中关于Exception的一道面试题.
今天看到Thinking in Java中一个关于Exception的例子:最后看到有一篇总结的比较好的文章, 这里拿来记录下, 文章地址是:http://blog.csdn.net/salerzhang/article/details/46581457 感谢原作者. 1 class Annoyance extends Exception {}2 class Sneeze extends Annoyance {}3 …

使用 .NET 框架轻松开发完美的 Web 窗体控件
作者:David S. Platt 出自:微软 本文假定您熟悉 Visual Basic .NET、C# 和 HTML 下载本文的代码: WebC.exe (274KB) 摘要 预建的自定义控件可以简化和加快应用程序的设计,并使您能够维护 UI 的一致性。但是,预先打…

史上最强女游戏程序员
也许你听说过John Carmack 和Tim Sweeney等大牛的名字,而向来游戏工业都是阳盛阴衰,适逢国际妇女节,今天我为大家介绍游戏业界一位史上最强女游戏程序员:Corrinne Yu。 简历 以下是她在游戏业界内的简历 微软Halo团队首席引擎架构…
重磅日程公布!与百名大咖在线交流技术,2天20个AI论坛不可错过
当全球都在面向 AI 变革时,AI 不再是触不可及,它需要产业化落地,为社会创造价值。在这一轮技术革命、技术浪潮中,开发者们成为构建任何一家AI企业的核心竞争力。不过,不同于此前只懂开发语言、数据结构便可轻松躲过新技…

Python取出列表相应值的位置(表处理)
#需求在一个列表中,取出相应值的位置方法1:#脚本示例[rootlocalhost opt]# cat list.py #!/usr/bin/env python #_*_ coding:utf-8 _*_ name[!,#,*,Eric,wsyht,jack,jack,a,b,c,d,1,2,3,4,5,6,1,2,3,4,5,6,1,2,3,4,5,6,2332,4,2,6,2] first_pos 0 for …

rhel5.5安装xwindow
rhel5.5安装xwindow 1安装xwindow yum groupinstall "X Window System" 2、安装GNOME桌面环境 yum groupinstall "GNOME Desktop Environment" 3、卸载GNOME桌面环境 yum groupremove "GNOME Desktop Environment"转载于:https://blog.51cto…

使用 ASP.NET 加密口令
作者:未知 请作者速与本人联系当我们在网站上建立数据库时,保护用户的信息安全是非常必要的。多数用户不愿意让别人知道自己的信息,同时网管也不想因为安全问题而丢失网站的信誉。无论对于谁,安全问题都是非常重要的。为了解决这…
算法鼻祖高德纳,82 岁仍在写《计算机程序设计的艺术》
作者 | 年素清编辑 | 伍杏玲出品 | CSDN(ID:CSDNnews)高德纳(Donald Ervin Knuth)被誉为现代计算机科学的鼻祖,毕生致力于编译程序、属性文法和运算法则等领域的前沿研究,共出版专著17部&#x…

centos查看特定程序占用端口情况
ps axu |grep 程序名,找到特定程序的pidnetstat -nltp |grep pid即可。转载于:https://blog.51cto.com/zhukeqiang/1811735

关于页面刷新的问题
在做.net开发时,经常能碰到这样的情况,页面很长,而我们一般用的都是服务器端控件,用服务器端控件有这样一个缺点,就是控件每次都要和服务器交互,而产生页面的刷新,试想一下,如果页面…
技术直播:程序员副业的修炼指南!(限免报名)
面试造飞机,上班拧螺丝,每天想辞职,但无奈副业还“大器晚成”的样子!那可能是你还没有选对副业!滴滴 ~福利卡!!!CSDN学院邀请汤小洋老师开设技术直播课《程序员副业之路-三大终极秘籍…