算法的出现帮助我们解决了生活中很多常见的问题,让一些事看起来没有那么的复杂。今天小千就来给大家介绍十个改变了计算机世界的算法。

什么是算法?

简而言之,任何定义明确的计算步骤都可称为算法,接受一个或一组值为输入,输出一个或一组值。(来源:homas H. Cormen, Chales E. Leiserson 《算法导论第3版》)可以这样理解,算法是用来解决特定问题的一系列步骤(不仅计算机需要算法,我们在日常生活中也在使用算法)。

算法必须具备如下3个重要特性:有穷性,执行有限步骤后,算法必须中止。确切性,算法的每个步骤都必须确切定义。

可行性,特定算法须可以在特定的时间内解决特定问题。

其实,算法虽然广泛应用在计算机领域,但却完全源自数学。实际上,最早的数学算法可追溯到公元前1600年-Babylonians有关求因式分解和平方根的算法。

那么,又是哪10个计算机算法造就了我们今天的生活呢?(请看下面的表单,排名不分先后)

1、归并排序(MERGE SORT)、快速排序(QUICK SORT)、堆积排序(HEAP SORT)


哪个排序算法效率最高?这要看情况。这也就是我把3种算法放在一起讲的原因,可能你更常用其中一种,不过它们各有千秋。归并排序算法,是目前为止最重要的算法之一,是分治法的一个典型应用,由数学家John von Neumann于1945年发明。快速排序算法,结合了集合划分算法和分治算法,不是很稳定,但在处理随机列阵(AM-based arrays)时效率相当高。堆积排序,采用优先伫列机制,减少排序时的搜索时间,同样不是很稳定。与早期的排序算法相比(如冒泡算法),这些算法将排序算法提上了一个大台阶。也多亏了这些算法,才有今天的数据发掘,人工智能,链接分析,以及大部分网页计算工具。

2、傅立叶变换、快速傅立叶变换


这两种算法简单,但却相当强大,整个数字世界都离不开它们,其功能是实现时间域函数与频率域函数之间的相互转化。能看到这篇文章,也是托这些算法的福。因特网,WIFI,智能机,座机,电脑,路由器,卫星等几乎所有与计算机相关的设备都或多或少与它们有关。不会这两种算法,你根本不可能拿到电子,计算机或者通信工程学位。(USA)

3、迪杰斯特拉算法 (Dijkstra’s algorithm)


可以这样说,如果没有这种算法,因特网肯定没有现在的高效率。只要能以“图”模型表示的问题,都能用这个算法找到“图”中两个节点间的最短距离。虽然如今有很多更好的方法来解决最短路径问题,但代克思托演算法的稳定性仍无法取代。

4、RSA非对称加密算法

毫不夸张地说,如果没有这个算法对密钥学和网络安全的贡献,如今因特网的地位可能就不会如此之高。现在的网络毫无安全感,但遇到钱相关的问题时我们必需要保证有足够的安全感,如果你觉得网络不安全,肯定不会傻乎乎地在网页上输入自己的银行卡信息。RSA算法,密钥学领域最牛叉的算法之一,由RSA公司的三位创始人提出,奠定了当今的密钥研究领域。用这个算法解决的问题简单又复杂:保证安全的情况下,如何在独立平台和用户之间分享密钥。

5、哈希算法(Hash Algorithm)

确切地说,这不是一种算法,而是一组加密哈希函数,由美国国家标准技术研究所首先提出。无论是你的应用商店,电子邮件和杀毒软件,还是浏览器等等,都使用这种算法来保证你正常下载,以及是否被“中间人攻击”,或者“网络钓鱼”。

6、整数质因子分解算法(Integer factorization)

7、链接分析算法(Link Analysis)


在因特网时代,不同入口间关系的分析至关重要。从搜索引擎和社交网站,到市场分析工具,都在不遗余力地寻找因特网的正真构造。链接分析算法一直是这个领域最让人费解的算法之一,实现方式不一,而且其本身的特性让每个实现方式的算法发生异化,不过基本原理却很相似。链接分析算法的机制其实很简单:你可以用矩阵表示一幅“图“,形成本征值问题。本征值问题可以帮助你分析这个“图”的结构,以及每个节点的权重。这个算法于1976年由Gabriel Pinski和Francis Narin提出。谁会用这个算法呢?Google的网页排名,Facebook向你发送信息流时(所以信息流不是算法,而是算法的结果),Google+和Facebook的好友推荐功能,LinkedIn的工作推荐,Youtube的视频推荐,等等。普遍认为Google是首先使用这类算法的机构,不过其实早在1996年(Google 问世2年前)李彦宏就创建的“RankDex”小型搜索引擎就使用了这个思路。而Hyper Search搜索算法建立者马西莫·马奇奥里也曾使用过类似的算法。这两个人都后来都成为了Google历史上的传奇人物。

8、比例微积分算法(Proportional Integral Derivative Algorithm)

飞机,汽车,电视,手机,卫星,工厂和机器人等等事物中都有这个算法的身影。简单来讲,这个算法主要是通过“控制回路反馈机制”,减小预设输出信号与真实输出信号间的误差。只要需要信号处理,或电子系统来控制自动化机械,液压和加热系统,都需要用到这个算个法。没有它,就没有现代文明。

9、数据压缩算法

数据压缩算法有很多种,哪种最好?这要取决于应用方向,压缩mp3,JPEG和MPEG-2文件都不一样。

哪里能见到它们?不仅仅是文件夹中的压缩文件。你正在看的这个网页就是使用数据压缩算法将信息下载到你的电脑上。除文字外,游戏,视频,音乐,数据储存,云计算等等都是。它让各种系统更轻松,效率更高。

10、随机数生成算法

到如今,计算机还没有办法生成“正真的”随机数,但伪随机数生成算法就足够了。

这些算法在许多领域都有应用,如网络连接,加密技术,安全哈希算法,网络游戏,人工智能,以及问题分析中的条件初始化。

希望本文的分享能帮到有需要的小伙伴!

本文来自千锋教育,转载请注明出处。

十个改变了计算机世界的算法,你知道几个?相关推荐

  1. shell sort 最后一列排序_十个必知的排序算法|Python实例系列[1]

    实例内容: 十个必知的排序算法具体代码,并简略的得知每种算法对于不同长度数列的排序时间 十大排序: 1.冒泡排序2.选择排序3.插入排序4.希尔排序5.归并排序6.快速排序7.堆排序8.计数排序9.桶 ...

  2. list 排序_十个必知的排序算法|Python实例系列

    十大排序: 1.冒泡排序2.选择排序3.插入排序4.希尔排序5.归并排序6.快速排序7.堆排序8.计数排序9.桶排序10.基数排序 完整代码和注释如下 # -*- coding: UTF-8 -*-# ...

  3. 十个改变降血压:每天吃四瓣蒜走六千步

    北京中医药大学养生室教授 张湖德 心脏.大脑.肾脏,有着共同的"无声杀手"--高血压.或许人们还没感到什么不适,就已经遭受了它的致命打击.在我国,超过2亿人已患上了高血压,而且有越 ...

  4. 走心整理——十个常用深度学习算法

    十分抱歉,由于项目太忙(我会说自己懒吗?)柳猫一直没有更新自己的手记,现在,就让柳猫来讲讲十个常用的深度学习算法. 过去十年里,人们对机器学习的兴趣经历了爆炸式的整长.我们几乎每天都可以在计算机程序. ...

  5. 换人!这些算法都不会还搞什么操作系统

    此篇文章带你梳理一下操作系统中都出现过哪些算法: 进程和线程管理中的算法 进程和线程在调度时候出现过很多算法,这些算法的设计背景是:当一个计算机是多道程序设计系统时,会频繁的有很多进程或者线程来同时竞 ...

  6. em算法的java实现_EM算法 - Java教程 - 找一找教程网

    1.背景 2.理论 2.1.Jensen不等式 优化理论中,假设 \(f\) 是定义域为实数的函数,如果对于所有的实数 \(x\) ,且二阶导数\(f''(x)\geq 0\) ,则 \(f\) 是凸 ...

  7. 机器学习算法与Python实践之(二)支持向量机

    http://blog.csdn.net/zouxy09/article/details/17291543 机器学习算法与Python实践这个系列主要是参考<机器学习实战>这本书.因为自己 ...

  8. Python数据结构与算法(第五天)

    34.栈与队列的概念 栈 栈(stack),有些地方称为堆栈,是一种容器,可存入数据元素.访问元素.删除元素,它的特点在于只能允许在容器的一端(称为栈顶端指标,英语:top)进行加入数据(英语:pus ...

  9. 机器学习算法与Python实践之(二)支持向量机(SVM)初级

    机器学习算法与Python实践之(二)支持向量机(SVM)初级 zouxy09@qq.com http://blog.csdn.net/zouxy09 机器学习算法与Python实践这个系列主要是参考 ...

最新文章

  1. 韩寒:出了国才知道,外国是多么的落后(写的真委婉~不愧是韩寒)
  2. matlab分类器设计,简单分类器的MATLAB实现.doc
  3. 怎么在服务器中修改sql权限设置密码,SQL server数据库的权限设置
  4. mysql绕过防火墙_[转载]使用sqlmap 绕过防火墙进行注入测试
  5. 大屏监控系统实战(16)-项目拾遗
  6. 电商视觉:焦点图的万能构图模板
  7. linux php7 替换,linux-shell-命令替换和变量替换
  8. 【转】VC++计算当前时间点间隔N天的时间(不使用CTimeSpan类)
  9. python3 读取文件夹的文件标题,提取小数,并计算数字和
  10. MATLAB数学建模方法与实践(第3版)——读书笔记
  11. 水利水电专业英语(2.5k行超全)
  12. 2021版Java同步器教程03:如何使用同步器 CyclicBarrier?
  13. 耗时86小时的「百变小樱」最强数据可视化作品!
  14. python主页面_使用Wagtail CMS使用Python检测父页面和子页面...
  15. WebSphere安装配置文档
  16. 虚拟机ping不通主机
  17. abr-summary 和asbr-summary命令中的not-advertise参数
  18. 高德地图如何同时显示多个InfoWindow信息窗体
  19. 夏普/sharp willcom d4 刷linux,IT豆
  20. 【20210416期AI简报】微软分层ViT模型开源、 DIY一只“眼睛”摄像头

热门文章

  1. 变分自编码器VAE:这样做为什么能成?
  2. Vision Transformer 论文
  3. 安卓scrollview无法滑动_安卓上线前,小光有话想对你们说
  4. Neo4j【付诸实践 01】SpringBoot集成报错org.neo4j.driver.exceptions.ClientException:服务器不支持此驱动程序支持的任何协议版本(解决+源代码)
  5. linux下php远程连接mysql_Linux下PHP远程连接Oracle数据库 | 系统运维
  6. 这都2021年了,还不会Feign性能调优?Feign性能调优之gzip压缩实现-自娱自乐篇
  7. BugKuCTF 加密 滴答~滴
  8. Fcrackzip——简介、安装、使用
  9. Long Long Message
  10. redhat 中配置静态 IP