热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

了解_编程界称霸全球的10大算法,你到底了解几个呢?

篇首语:本文由编程笔记#小编为大家整理,主要介绍了编程界称霸全球的10大算法,你到底了解几个呢?相关的知识,希望对你有一定的参考价值。

篇首语:本文由编程笔记#小编为大家整理,主要介绍了编程界称霸全球的10大算法,你到底了解几个呢?相关的知识,希望对你有一定的参考价值。











来源:课程图谱博客



















本文约2300字,建议阅读9分钟



本文带你了解编程界称霸全球的十大算法。












算法究竟是什么?










简而言之,算法代表经过明确定义的计算过程,用于将输入转化为输出。






可以这样理解,算法是用来解决特定问题的一系列步骤(不仅计算机需要算法,我们在日常生活中也在使用算法)。就目前来看,具有以下三大特征的算法才具备实际效果:






  • 有穷性执行有限步骤后,算法必须终止;


  • 确切性:算法的每个步骤都必须确切定义;


  • 可行性:特定算法需可以在特定的时间内解决特定问题。










此外,需要强调的是,算法的应用不仅局限于计算机科学,同时它也作为一种数学实体。早在公元前1600年,巴比伦人就发现了用于求因式分解和平方根的算法。如果将算法视作数学实体,那么称霸世界的十大算法极可能为算术方法(如加、减、乘、除等)。






如果按照本文中算法的定义,称霸世界的十种算法究竟有哪些呢?在这里,我列出了一份小小的清单,排名不分先后。








合并排序、快速排序与堆排序








编程界称霸全球的10大算法,你到底了解几个呢?






哪个排序算法效率最高?这要分情况讨论。因此我将这3种算法放在一起来讲,可能你更常用其中一种,但事实上三者都很重要。






合并算法是迄今为止我们所拥有的最重要的算法之一,是分治法的一个典型应用,由数学家John von Neumann于1945年发明。






快速排序算法,结合了集合划分算法和分治算法,虽该算法并不是很稳定,但在对基于内存的数组进行排序时表现非常出色。






最后是堆排序,其采用优先伫列机制,减少排序时的搜索时间,同样不是很稳定。






但这些算法相较于之前的冒泡排序等,有了很大的改进。也多亏了这些算法,才有今天的数据发掘,人工智能,链接分析,以及大部分网页计算工具。








傅利叶变换与快速傅利叶变换








编程界称霸全球的10大算法,你到底了解几个呢?






这两种算法简单,但却相当强大,整个数字世界都离不开它们,其功能是实现时间域函数与频率域函数之间的相互转化。能看到这篇文章,也是托这些算法的福。






因特网,WIFI,智能机,座机,电脑,路由器,卫星等几乎所有与计算机相关的设备都或多或少与它们有关。
不会这两种算法,你根本不可能拿到电子,计算机或者通信工程学位。








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








编程界称霸全球的10大算法,你到底了解几个呢?






可以这样说,如果没有这种算法,因特网肯定没有现在的高效率。只要能以“图”模型表示的问题,都能用这个算法找到“图”中两个节点间的最短距离。






虽然如今有很多更好的方法来解决最短路径问题,但代克思托演算法的稳定性仍无法取代。








RSA非对称加密算法








如果没有这个算法对密钥学和网络安全的贡献,如今因特网的地位可能就不会如此之高。
现在的网络毫无安全感,但遇到钱相关的问题时我们必须要保证有足够的安全感,如果你觉得网络不安全,肯定不会傻乎乎地在网页上输入自己的银行卡信息。








RSA算法,密钥学领域最厉害的算法之一,由RSA公司的三位创始人提出,奠定了当今的密钥研究领域。用这个算法解决的问题简单又复杂:保证安全的情况下,如何在独立平台和用户之间分享密钥。






编程界称霸全球的10大算法,你到底了解几个呢?








哈希安全算法(Secure Hash Algorithm)








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






编程界称霸全球的10大算法,你到底了解几个呢?








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








这其实是一个数学算法,不过已经广泛应用于计算机领域。如果没有这个算法,密码学技术的安全水平将受到严重破坏。该算法用于将复合数的质数因子分解到较小的非零因数。也被称为FNP类问题,属于NP类问题的拓展,且解决难度极高。






很多加密协议都采用了这个算法,就比如刚提到的RSA算法。








链接分析算法(Link Analysis)








编程界称霸全球的10大算法,你到底了解几个呢?






在互联网时代,不同入口间关系的分析至关重要。从搜索引擎和社交网站,到市场分析工具,都在不遗余力地寻找因特网的正真构造。






链接分析算法一直是这个领域最让人费解的算法之一,实现方式不一,而且其本身的特性让每个实现方式的算法发生异化,不过基本原理却很相似。






链接分析算法的机制其实很简单:你可以用矩阵表示一幅“图“,形成本征值问题。本征值问题可以帮助你分析这个“图”的结构,以及每个节点的权重。这个算法于1976年由Gabriel Pinski和Francis Narin提出。






谁会用这个算法呢?Google的网页排名,Facebook向你发送信息流时(所以信息流不是算法,而是算法的结果),Google+和Facebook的好友推荐功能,LinkedIn的工作推荐,Youtube的视频推荐,等等。虽然其各自拥有不同的目标与参数组合,但背后的数学原理却是相通的。






最后,我想说一点,很多人普遍认为Google是首先使用这类算法的机构,不过其实早在1996年(Google 问世2年前)李彦宏就创建的“RankDex”小型搜索引擎就使用了这个思路。而Hyper Search搜索算法建立者马西莫·马奇奥里也曾使用过类似的算法。这两个人都后来都成为了Google历史上的传奇人物。








比例微积分算法








编程界称霸全球的10大算法,你到底了解几个呢?








飞机,汽车,电视,手机,卫星,工厂和机器人等等事物中都有这个算法的身影。






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








数据压缩算法










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






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








随机数生成算法














到如今,计算机还没有办法生成“真正的”随机数,但伪随机数生成算法就足够了。
这些算法在许多领域都有应用,如网络连接,加密技术,安全哈希算法,网络游戏,人工智能,以及问题分析中的条件初始化。






总结






总的来说,计算机的发展放到应用和数据飞速增长的大环境下,我们会发现:
算法的重要性不是在日益减小,而是在日益加强。






http://blog.coursegraph.com/统计学公开课大盘点



编辑:于腾凯



推荐阅读
  • 本文介绍了新款奇骏的两个让人上瘾的功能,分别是智能互联系统和BOSE音响。通过对新款奇骏的配置和功能进行评测,探讨了这两个新增功能的使用体验和优势。此外,还介绍了新款奇骏的其他配置和改进,如增加的座椅和驾驶辅助系统,以及内饰的舒适性提升。对于喜欢音响的消费者来说,BOSE音响的升级也是一个亮点。最后,文章提到了BOSE音响的数字还原能力,以及7座版无法配备BOSE音响的原因。 ... [详细]
  • 转自:微点阅读(www.weidianyuedu.com)微点阅读-范文大全-免费学习知识的网站电脑唯独搜不到自己家wifi,别人家的都能搜到,手机也可以搜到自己家的,就是电脑不可 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • 如何配置小米wifi放大器来增强家庭无线路由器信号?
    本文介绍了如何通过配置小米wifi放大器来增强家庭无线路由器信号的方法。通过打开米家APP,选择设备添加,搜索并选择需要添加的wifi放大器,根据系统提示进行下一步操作即可完成配置。配置完成后,家庭无线路由器信号将得到增强。 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 无线认证设置故障排除方法及注意事项
    本文介绍了解决无线认证设置故障的方法和注意事项,包括检查无线路由器工作状态、关闭手机休眠状态下的网络设置、重启路由器、更改认证类型、恢复出厂设置和手机网络设置等。通过这些方法,可以解决无线认证设置可能出现的问题,确保无线网络正常连接和上网。同时,还提供了一些注意事项,以便用户在进行无线认证设置时能够正确操作。 ... [详细]
  • 本文介绍了互联网思维中的三个段子,涵盖了餐饮行业、淘品牌和创业企业的案例。通过这些案例,探讨了互联网思维的九大分类和十九条法则。其中包括雕爷牛腩餐厅的成功经验,三只松鼠淘品牌的包装策略以及一家创业企业的销售额增长情况。这些案例展示了互联网思维在不同领域的应用和成功之道。 ... [详细]
  • Shodan简单用法Shodan简介Shodan是互联网上最可怕的搜索引擎,与谷歌不同的是,Shodan不是在网上搜索网址,而是直接进入互联网的背后通道。Shodan可以说是一款“ ... [详细]
  • 家里没有台式机,在手机上怎么设置密码?
      1、先将网线(猫出来的网线)插在路由器的WAN口,开启无线路由器的电源在手机上设置路由器。2、手机打开无线搜索路由器,连接无线路由器(新路由器 ... [详细]
  • pc电脑如何投屏到电视?DLNA主要步骤通过DLNA连接,使用WindowsMediaPlayer的流媒体播放举例:电脑和电视机都是连接的 ... [详细]
  • 周鸿祎火力全开
    “在这个IoT时代,只是孤立地搞大数据,孤立地搞云,或谈AI,或做一个智能硬件,我觉得都是不完备的,必须将这几项技术综合运用起来,才是一个真正的IoT时代,也是IoT真正的春天。” ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • Java程序设计第4周学习总结及注释应用的开发笔记
    本文由编程笔记#小编为大家整理,主要介绍了201521123087《Java程序设计》第4周学习总结相关的知识,包括注释的应用和使用类的注释与方法的注释进行注释的方法,并在Eclipse中查看。摘要内容大约为150字,提供了一定的参考价值。 ... [详细]
  • 本文讨论了微软的STL容器类是否线程安全。根据MSDN的回答,STL容器类包括vector、deque、list、queue、stack、priority_queue、valarray、map、hash_map、multimap、hash_multimap、set、hash_set、multiset、hash_multiset、basic_string和bitset。对于单个对象来说,多个线程同时读取是安全的。但如果一个线程正在写入一个对象,那么所有的读写操作都需要进行同步。 ... [详细]
  • scrcpy通过adb调试的方式来将手机屏幕投到电脑上,并可以通过电脑控制您的Android设备。它可以通过USB连接,也可以通过Wifi连接(类似于隔空投屏),而且不需要任何ro ... [详细]
author-avatar
雨后彩虹fen
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有