算法(Algorithm)是指解题方案的准确而完整的描述,是一系列解决问题的清晰指令,算法代表着用系统的方法描述解决问题的策略机制。也就是说,能够对一定规范的输入,在有限时间内获得所要求的输出。如果一个算法有缺陷,或不适合于某个问题,执行这个算法将不会解决这个问题。不同的算法可能用不同的时间、空间或效率来完成同样的任务。一个算法的优劣可以用空间复杂度与时间复杂度来衡量。
算法中的指令描述的是一个计算,当其运行时能从一个初始状态和(可能为空的)初始输入开始,经过一系列有限而清晰定义的状态,最终产生输出并停止于一个终态。一个状态到另一个状态的转移不一定是确定的。随机化算法在内的一些算法,包含了一些随机输入。
形式化算法的概念部分源自尝试解决希尔伯特提出的判定问题,并在其后尝试定义有效计算性或者有效方法中成形。这些尝试包括库尔特·哥德尔、Jacques Herbrand和斯蒂芬·科尔·克莱尼分别于1930年、1934年和1935年提出的递归函数,阿隆佐·邱奇于1936年提出的λ演算,1936年Emil Leon Post的Formulation 1和艾伦·图灵1937年提出的图灵机。即使在当前,依然常有直觉想法难以定义为形式化算法的情况。

特征

一个算法应该具有以下五个重要的特征:

有穷性

(Finiteness)
算法的有穷性是指算法必须能在执行有限个步骤之后终止;

确切性

(Definiteness)
算法的每一步骤必须有确切的定义;

输入项

(Input)
一个算法有0个或多个输入,以刻画运算对象的初始情况,所谓0个输入是指算法本身定出了初始条件;

输出项

(Output)
一个算法有一个或多个输出,以反映对输入数据加工后的结果。没有输出的算法是毫无意义的;

可行性

(Effectiveness)
算法中执行的任何计算步骤都是可以被分解为基本的可执行的操作步,即每个计算步都可以在有限时间内完成(也称之为有效性)。

要素

一,数据对象的运算和操作:计算机可以执行的基本操作是以指令的形式描述的。一个计算机系统能执行的所有指令的集合,成为该计算机系统的指令系统。一个计算机的基本运算和操作有如下四类: [1]
1, 算术运算:加减乘除等运算
2, 逻辑运算:或、且、非等运算
3, 关系运算:大于、小于、等于、不等于等运算
4, 数据传输:输入、输出、赋值等运算 [1]
二,算法的控制结构:一个算法的功能结构不仅取决于所选用的操作,而且还与各操作之间的执行顺序有关。 [1]

评定

同一问题可用不同算法解决,而一个算法的质量优劣将影响到算法乃至程序的效率。 算法分析的目的在于选择合适算法和改进算法。一个算法的评价主要从 时间复杂度空间复杂度来考虑。

时间复杂度

算法的时间复杂度是指执行算法所需要的计算工作量。一般来说,计算机算法是问题规模n 的函数f(n),算法的时间复杂度也因此记做。
T(n)=Ο(f(n))
因此,问题的规模n 越大,算法执行的时间的增长率与f(n) 的增长率正相关,称作 渐进时间复杂度(Asymptotic Time Complexity)。

空间复杂度

算法的空间复杂度是指算法需要消耗的内存空间。其计算和表示方法与时间 复杂度类似,一般都用复杂度的渐近性来表示。同时间复杂度相比,空间复杂度的分析要简单得多。

正确性

算法的正确性是评价一个算法优劣的最重要的标准。

可读性

算法的可读性是指一个算法可供人们阅读的容易程度。 [1]

健壮性

[1]
健壮性是指一个算法对不合理数据输入的反应能力和处理能力,也称为 容错性[1]

方法

递推法

递推是 序列 计算机中的一种常用算法。它是按照一定的规律来计算序列中的每个项,通常是通过计算机前面的一些项来得出序列中的指定项的值。其思想是把一个复杂的 庞大的计算过程转化为 简单 过程的多次 重复,该算法利用了计算机速度快和 不知疲倦的机器特点。

递归法

程序调用自身的编程技巧称为 递归(recursion)。一个过程或 函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的 语句来定义对象的 无限集合。一般来说,递归需要有 边界条件、递归前进段和递归返回段。当边界条件不满足时,递归前进;当边界条件满足时,递归返回。
注意:
(1) 递归就是在过程或 函数里调用自身;
(2) 在使用递归策略时,必须有一个明确的递归结束条件,称为递归出口。

穷举法

穷举法,或称为 暴力破解法,其基本思路是:对于要解决的问题,列举出它的所有可能的情况,逐个判断有哪些是符合问题所要求的条件,从而得到问题的解。它也常用于对于 密码的 破译,即将密码进行逐个推算直到找出真正的密码为止。例如一个已知是四位并且全部由数字组成的密码,其可能共有10000种组合,因此最多尝试10000次就能找到正确的密码。理论上利用这种方法可以破解任何一种密码,问题只在于如何缩短试误时间。因此有些人运用计算机来增加效率,有些人辅以字典来缩小 密码组合的范围。

贪心算法

贪心算法是一种对某些求最优解问题的更 简单、更迅速的设计技术。
用贪心法设计算法的特点是一步一步地进行,常以当前情况为基础根据某个优化测度作最优选择,而不考虑各种可能的整体情况,它省去了为找 最优解要穷尽所有可能而必须耗费的大量时间,它采用自顶向下,以迭代的方法做出相继的贪心选择,每做一次贪心选择就将所求问题简化为一个规模更小的子问题, 通过每一步贪心选择,可得到问题的一个最优解,虽然每一步上都要保证能获得局部最优解,但由此产生的全局解有时不一定是最优的,所以贪婪法不要回溯。
贪婪算法是一种改进了的分级处理方法,其核心是根据题意选取一种量度标准,然后将这多个输入排成这种量度标准所要求的顺序,按这种顺序一次输入一个量,如果这个输入和当前已构成在这种量度意义下的部分最佳解加在一起不能产生一个 可行解,则不把此输入加到这部分解中。这种能够得到某种量度意义下最优解的分级处理方法称为贪婪算法。
对于一个给定的问题,往往可能有好几种量度标准。初看起来,这些量度标准似乎都是可取的,但实际上,用其中的大多数量度标准作贪婪处理所得到该量度意义下的最优解并不是问题的最优解,而是次优解。因此,选择能产生问题最优解的最优量度标准是使用贪婪算法的核心。
一般情况下,要选出最优量度标准并不是一件容易的事,但对某问题能选择出最优量度标准后,用贪婪算法求解则特别有效。

分治法

分治法是把一个复杂的问题分成两个或更多的相同或相似的子问题,再把子问题分成更小的子问题……直到最后子问题可以简单的直接求解,原问题的解即子问题的解的合并。
分治法所能解决的问题一般具有以下几个特征:
(1) 该问题的规模缩小到一定的程度就可以容易地解决;
(2) 该问题可以分解为若干个规模较小的相同问题,即该问题具有最优子结构性质;
(3) 利用该问题分解出的子问题的解可以合并为该问题的解;
(4) 该问题所分解出的各个子问题是相互独立的,即子问题之间不包含公共的子子问题。

动态规划法

动态规划是一种在数学和 计算机科学中使用的,用于求解包含重叠子问题的最优化问题的方法。其基本思想是,将原问题分解为相似的子问题,在求解的过程中通过子问题的解求出原问题的解。动态规划的思想是多种算法的基础,被广泛应用于计算机科学和工程领域。
动态规划程序设计是对解最优化问题的一种途径、一种方法,而不是一种特殊算法。不象前面所述的那些搜索或数值计算那样,具有一个标准的数学表达式和明确清晰的解题方法。动态规划程序设计往往是针对一种 最优化问题,由于各种问题的性质不同,确定最优解的条件也互不相同,因而动态规划的设计方法对不同的问题,有各具特色的解题方法,而不存在一种万能的动态规划算法,可以解决各类最优化问题。因此读者在学习时,除了要对基本概念和方法正确理解外,必须具体问题具体分析处理,以丰富的想象力去建立模型,用创造性的技巧去求解。

迭代法

迭代法也称 辗转 法,是一种不断用变量的旧值 递推新值的过程,跟迭代法相对应的是直接法(或者称为一次解法),即一次性解决问题。迭代法又分为精确迭代和近似迭代。“ 二分法”和“ 牛顿迭代法”属于近似迭代法。迭代算法是用计算机解决问题的一种基本方法。它利用计算机运算速度快、适合做重复性操作的特点,让计算机对一组指令(或一定步骤)进行重复执行,在每次执行这组指令(或这些步骤)时,都从变量的原值推出它的一个新值。

分支界限法

分枝界限法是一个用途十分广泛的算法,运用这种算法的技巧性很强,不同类型的问题解法也各不相同。
分支定界法的基本思想是对有 约束条件的 最优化问题的所有 可行解(数目有限)空间进行搜索。该算法在具体执行时,把全部可行的 解空间不断分割为越来越小的 子集(称为分支),并为每个子集内的解的值计算一个下界或 上界(称为定界)。在每次分支后,对凡是界限超出已知可行解值那些子集不再做进一步分支,这样,解的许多子集(即搜索树上的许多结点)就可以不予考虑了,从而缩小了搜索范围。这一过程一直进行到找出 可行解为止,该可行解的值不大于任何子集的界限。因此这种算法一般可以求得 最优解。
与 贪心算法一样,这种方法也是用来为 组合 优化问题设计求解算法的,所不同的是它在问题的整个可能解空间搜索,所设计出来的算法虽其 时间复杂度比 贪婪算法高,但它的优点是与 穷举法类似,都能保证求出问题的最佳解,而且这种方法不是盲目的穷举搜索,而是在搜索过程中通过 限界,可以中途停止对某些不可能得到最优解的子空间进一步搜索(类似于人工智能中的剪枝),故它比穷举法 效率更高。

回溯法

回溯法(探索与回溯法)是一种选优搜索法,按选优条件向前搜索,以达到目标。但当探索到某一步时,发现原先选择并不优或达不到目标,就退回一步重新选择,这种走不通就退回再走的技术为回溯法,而满足回溯条件的某个 状态的点称为“回溯点”。
其基本思想是,在包含问题的所有解的解空间树中,按照深度优先搜索的策略,从根结点出发深度探索解空间树。当探索到某一结点时,要先判断该结点是否包含问题的解,如果包含,就从该结点出发继续探索下去,如果该结点不包含问题的解,则逐层向其祖先结点回溯。(其实回溯法就是对隐式图的深度优先搜索算法)。 若用回溯法求问题的所有解时,要回溯到根,且根结点的所有可行的子树都要已被搜索遍才结束。 而若使用回溯法求任一个解时,只要搜索到问题的一个解就可以结束。

描述方式

描述算法的方法有多种,常用的有自然语言、结构化 流程图、 伪代码和 PAD图等,其中最普遍的是流程图。

分类

算法可大致分为基本算法、数据结构的算法、 数论与代数算法、计算几何的算法、 图论的算法、 动态规划以及 数值分析、 加密算法、 排序算法、检索算法、随机化算法、并行算法,厄米变形模型,随机森林算法。
算法可以宏泛的分为 三类
一,有限的,确定性算法 这类算法在有限的一段时间内终止。他们可能要花很长时间来执行指定的任务,但仍将在一定的时间内终止。这类算法得出的结果常取决于输入值。
二,有限的,非确定算法 这类算法在有限的时间内终止。然而,对于一个(或一些)给定的数值,算法的结果并不是唯一的或确定的。
三,无限的算法 是那些由于没有定义终止定义条件,或定义的条件无法由输入的数据满足而不终止运行的算法。通常,无限算法的产生是由于未能确定的定义终止条件。

历史

“算法”即演算法的大陆中文名称出自《 周髀算经》;而英文名称Algorithm 来自于9世纪波斯数学家al-Khwarizmi,因为al-Khwarizmi在数学上提出了算法这个概念。“算法”原为"algorism",意思是阿拉伯数字的运算法则,在18世纪演变为"algorithm"。 欧几里得算法被人们认为是史上第一个算法。 第一次编写程序是Ada Byron于1842年为巴贝奇分析机编写求解 伯努利方程的程序,因此Ada Byron被大多数人认为是世界上第一位 程序员。因为查尔斯·巴贝奇(Charles Babbage)未能完成他的巴贝奇分析机,这个算法未能在巴贝奇分析机上执行。 因为"well-defined procedure"缺少数学上精确的定义,19世纪和20世纪早期的数学家、 逻辑学家在定义算法上出现了困难。20世纪的英国数学家 图灵提出了著名的图灵论题,并提出一种假想的计算机的抽象模型,这个模型被称为 图灵机。图灵机的出现解决了算法定义的难题,图灵的思想对算法的发展起到了重要作用。

算法(Algorithm)相关推荐

  1. 算法(algorithm) 技能树测评

    算法algorithm 技能树测评 1.使用体验 1.1 算法(algorithm)技能树介绍: 1.2 算法(algorithm)技能树使用: 1.3 优缺点分析 2.改进建议: 3.结论 1.使用 ...

  2. 算法 - algorithm

    算法 - algorithm 1.基础算法 1.1 使用蛇形给二维数组赋值 - 矩形 效果: 分析: 首先从数组的最后一列开始给二维数组赋值,即列不变,行增加.再从最后一列向右边依次给元素赋值,等到给 ...

  3. 出自上帝之手的精妙算法 - Algorithm from THE BOOK (1)

            <Proofs from THE BOOK>是一本非常出名的书籍, 收录了不少精妙的证明.         类似地, 在cstheory.stackexchange.com ...

  4. STL算法algorithm,

    2019独角兽企业重金招聘Python工程师标准>>> STL算法部分主要由头文件<algorithm>,<numeric>,<functional&g ...

  5. (实用简单版)latex如何书写算法algorithm

    文章目录 前言 一个例子 前言 看过很多使用latex写算法的,都感觉好复杂,导入的包就20,30个.这次我们使用algoritim2e包,感觉这个好用. \usepackage[lined,boxe ...

  6. 【算法Algorithm】计数(Count)排序

    算法思想 计数排序是非比较排序,即没有像arr[i] < arr[i + 1]这样的比较. 该算法适用于数量大且值的范围小的待排序数组,例如:待排序数组长度是1w(或10w,100w),但数组中 ...

  7. 【算法Algorithm】快速(Quick)排序

    算法思想 从待排序数组中找一个索引位置(例如,中间位置.开始位置.结束位置)的数作为轴,以这个轴为基准,把大于这个轴的数放到它的后面,把小于这个轴的数放到它的前面,至于相等的可以放在前面也可以放在后面 ...

  8. Algorithm:【Algorithm算法进阶之路】之十大经典排序算法

    Algorithm:[Algorithm算法进阶之路]之十大经典排序算法 相关文章 Algorithm:[Algorithm算法进阶之路]之数据结构二十多种算法演示 Algorithm:[Algori ...

  9. Algorithm:【Algorithm算法进阶之路】之数据结构基础知识

    Algorithm:[Algorithm算法进阶之路]之数据结构基础知识 相关文章 Algorithm:[Algorithm算法进阶之路]之数据结构二十多种算法演示 Algorithm:[Algori ...

  10. Algorithm:【Algorithm算法进阶之路】之数据结构二十多种算法演示

    Algorithm:[Algorithm算法进阶之路]之数据结构二十多种算法演示 目录 一.数据结构算法 1.顺序表 2.链表 3.栈和队列 4.串的模式匹配 5.稀疏矩阵 6.广义表 7.二叉树 8 ...

最新文章

  1. Copilot 真会砸了程序员的饭碗?
  2. 1月31日云栖精选夜读:阿里云客户案例研究:罗辑思维
  3. iphone 常用预编译代码
  4. php svn up,php中执行svn update问题
  5. 字典数组根据某key排序
  6. vb6 串口同时读取写入数据怎么避免冲突_实例:S7-200 SMART通过Modbus-RTU读取温湿度传感器数据...
  7. android 应用程序 判断 ,如何判断Android应用程序是否正在前台运行?
  8. html div 球形,CSS3 简单的球形构造
  9. c语言文件操作函数(未完待续)
  10. Socket超时时间设置
  11. java exec waitfor,Java Process waitFor()方法与示例
  12. 清除Eclipse和Myeclipse中的工作空间目录
  13. linux 解压war到root_解压war包的解压软件 war包可以用解压工具解开吗
  14. 《人月神话》读后感与读书笔记
  15. 安卓虚拟机_安卓虚拟机Pro解锁付费版 自带root权限 可运行xp等框架
  16. arduino系列教程之触摸开关(外部中断)开关小灯led
  17. 留学生 电脑安全与维护手册 (留学须知)
  18. 图像处理基础与理解 随笔一 图像的内插
  19. 【Git】GitHub flow笔记 | GitHub flow和Git flow的区别
  20. 大时钟暗物质云计算机,《雄兵中》卡尔的大时钟是怎么来的?大时钟在他手里是好是坏?...

热门文章

  1. C/C++中的绝对值函数
  2. URLEncoder.encode(str,编码) new URLDecoder().decode(str,编码)
  3. 蓝桥杯-第九届决赛——采油
  4. 1 赫斯曼网管软件industrial hivision下载步骤
  5. 一篇博客学会了坦克大战
  6. outlook 邮箱过期问题处理
  7. tokenizer()和tokenizer.encode_plus()的区别
  8. 网络舆情分析关键词怎么获取的系统平台方法
  9. 需求工程之原型法获取需求
  10. 【推荐算法】探索与利用