`

十大算法

 
阅读更多
什么是算法?

简而言之,任何定义明确的计算步骤都可称为算法,接受一个或一组值为输入,输出一个或一组值。(来源: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. 哈希安全算法(Secure Hash Algorithm)

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

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

这其实是一个数学算法,不过已经广泛应用与计算机领域。如果没有这个算法,加密信息也不会如此安全。通过一系列步骤将,它可以将一个合成数分解成不可再分的数因子。

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

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. 随机数生成算法

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

相关推荐

    机器学习十大算法.zip

    《机器学习十大算法》压缩包包含了十个在机器学习领域中广泛应用的算法的详细介绍,每份PDF文件分别对应一个算法。这些算法是机器学习初学者和专业研究者必备的基础知识,涵盖了监督学习、非监督学习以及关联规则...

    数学建模十大算法程序详解.zip

    "数学建模十大算法程序详解.zip"这个压缩包包含了十个常用的数学建模算法,这些算法通常在解决实际问题时扮演着重要角色。下面,我们将详细讨论这些算法及其在MATLAB环境中的应用。 1. **线性规划**:线性规划是一...

    十大算法精讲资料.rar

    《十大算法精讲资料》是一份综合性的学习资源,涵盖了数据结构与算法的多个核心领域。这份压缩包中,你将找到对树、图、线性表、栈、队列、动态规划以及回溯等重要算法的详尽解析。下面,我们将深入探讨这些算法的...

    数学建模十大算法

    "数学建模十大算法"通常指的是在数学建模过程中最常用且实用的算法集合。这些算法不仅在数学领域有广泛应用,在工程、经济、生物、计算机科学等多个领域也发挥着重要作用。以下是对这十大算法的详细介绍: 1. **...

    数模十大算法

    【数模十大算法详解】 1. 蒙特卡罗算法 蒙特卡罗算法是一种基于随机抽样或统计试验的计算方法,广泛应用于解决复杂问题。它通过大量随机试验来逼近问题的解,适用于计算量大、解析解难以求得的情况。例如,在97年的...

    统治世界的十大算法

    ### 统治世界的十大算法详解 #### 一、排序算法:归并排序、快速排序及堆排序 **归并排序**是由约翰·冯·诺伊曼于1945年发明的一种经典排序算法。它是一种稳定的排序算法,采用的是分而治之的思想,通过递归的...

    数模十大算法论文。。。。。。

    本文将详细讨论被称为“数模十大算法”的一系列方法,特别是其中与遗传学相关的算法。这十大算法是解决数学建模问题的常用工具,涵盖了优化、模拟、预测等多个方面。 首先,我们要了解的是遗传算法(Genetic ...

    数据挖掘十大算法.pdf

    数据挖掘十大算法是该领域内影响力和应用范围最广的算法集合,对于数据分析师和数据科学工程师而言,掌握这些算法是必要的技能之一。 1. C4.5算法:C4.5是一种决策树算法,它是基于信息增益准则来选择特征,构建...

    机器学习十大算法之一 C4.5算法

    ### 机器学习十大算法之一:C4.5算法深度解析 #### 一、引言 在机器学习领域,C4.5算法作为决策树算法的一种,由Ross Quinlan于1993年提出,是ID3算法的升级版本。C4.5不仅解决了ID3算法的一些缺陷,如不能处理...

    数据挖掘十大算法

    数据挖掘十大算法,清华大学出版社。 有两个文件,小的没有封面,根据需要自行阅读吧。

    数学建模十大算法程序详解(打包了)

    本压缩包包含了对“十大算法程序”的详细讲解,为参赛者提供了宝贵的参考资料。以下是对这十大算法的概述: 1. **线性规划**:线性规划是最基础的优化方法,用于解决目标函数与约束条件均为线性关系的问题。通过...

    数学建模十大算法详解

    以下是对"数学建模十大算法详解"中可能包含的一些重要算法的详细介绍: 1. **线性规划**:这是最基础的优化算法之一,用于在满足一组线性约束条件下,最大化或最小化一个线性目标函数。例如,资源分配问题、生产...

    机器学习十大算法:AdaBoost.pdf

    在标题和描述中提到的“机器学习十大算法:AdaBoost.pdf”很可能是一篇介绍AdaBoost算法在机器学习中地位的文档。文档中出现的“AdaBoost算法”、“分类问题”、“指数损失函数”、“逻辑回归模型”、“加性逻辑回归...

    机器学习十大算法

    本节将深入探讨“机器学习十大算法”,这些算法是构建高效机器学习模型的基础,广泛应用于各种实际问题,如图像识别、自然语言处理、推荐系统等。 1. **朴素贝叶斯算法 (Naive Bayes)**:基于概率理论的分类算法,...

    机器学习和数据挖掘-十大算法.rar

    "机器学习和数据挖掘-十大算法.rar"这个压缩包文件显然聚焦于介绍十种在这些领域广泛应用的算法。这些算法是解决问题的基础工具,对于理解和解决复杂问题具有深远的影响。以下是关于这十大算法的详细解释: 1. **...

    数据挖掘领域十大算法代码实现CART.rar

    《数据挖掘领域十大算法代码实现CART》 在数据挖掘领域,CART(Classification and Regression Trees,分类与回归树)是一种广泛应用的算法,它能够处理分类和连续数值预测问题。本压缩包包含的是CART算法的Python...

    数据挖掘十大算法吴信东 英文版

    吴信东教授是数据挖掘领域的知名专家,他所提及的“数据挖掘十大算法”是一本深入探讨该领域核心技术的经典著作,英文版名为《The Top Ten Algorithms in Data Mining》。这本书为读者揭示了数据挖掘中最常用且具有...

Global site tag (gtag.js) - Google Analytics