首页 >
算法
✍ dations ◷ 2024-12-22 20:21:35 #算法
算法(algorithm),在数学(算学)和计算机科学之中,为任何一系列良定义的具体计算步骤,常用于计算、数据处理(英语:Data processing)和自动推理。作为一个有效方法(英语:Effective method),算法被用于计算函数,它包含了一系列定义清晰的指令,并可于有限的时间及空间内清楚的表述出来。算法中的指令描述的是一个计算,当其运行(英语:Execution (computing))时能从一个初始状态和初始输入(可能为空)开始,经过一系列有限而清晰定义的状态最终产生输出并停止于一个终态。一个状态到另一个状态的转移不一定是确定的。包括随机化算法在内的一些算法,都包含了一些随机输入。早在尝试解决希尔伯特提出的判定问题时,关于算法的一个不完全的概念已经初步定型,并在其后的正式化阶段中尝试定义“有效可计算性(英语:Effective calculability)”或者“有效方法(英语:Effective method)”。这些尝试包括库尔特·哥德尔、雅克·埃尔布朗和斯蒂芬·科尔·克莱尼分别于1930年、1934年和1935年提出的递归函数,阿隆佐·邱奇于1936年提出的λ演算,1936年埃米尔·莱昂·珀斯特(英语:Emil Leon Post)的Formulation 1和艾伦·图灵1937年提出的图灵机。即使在当下,依然常有符合直觉的想法难以定义为形式化算法的情况。算法在中国古代文献中称为“术”,最早出现在《周髀算经》、《九章算术》。特别是《九章算术》,给出四则运算、最大公约数、最小公倍数、开平方根、开立方根、求素数的埃拉托斯特尼筛法,线性方程组求解的算法。三国时代的刘徽给出求圆周率的算法:刘徽割圆术。自唐代以来,历代更有许多专门论述“算法”的专著:而英文名称“algorithm”来自于9世纪波斯数学家花拉子米(比阿勒·霍瓦里松,波斯语:خوارزمی ,拉丁转写:al-Khwarizmi),因为比阿勒·霍瓦里松在数学上提出了算法这个概念。“算法”原为“algorism”,即“al-Khwarizmi”的音转,意思是“花拉子米”的运算法则,在18世纪演变为“algorithm”。欧几里得算法被人们认为是史上第一个算法。第一次编写程序是爱达·勒芙蕾丝(Ada Byron)于1842年为巴贝奇分析机编写求解解伯努利微分方程的程序,因此爱达·勒芙蕾丝被大多数人认为是世界上第一位程序员。因为查尔斯·巴贝奇(Charles Babbage)未能完成他的巴贝奇分析机,这个算法未能在巴贝奇分析机上执行。因为“well-defined procedure”缺少数学上精确的定义,19世纪和20世纪早期的数学家、逻辑学家在定义算法上出现了困难。20世纪的英国数学家图灵提出了著名的图灵论题,并提出一种假想的计算机的抽象模型,这个模型被称为图灵机。图灵机的出现解决了算法定义的难题,图灵的思想对算法的发展起到了重要的作用。以下是高德纳在他的著作《计算机程序设计艺术》里对算法的特征归纳:算法的核心是创建问题抽象的模型和明确求解目标,之后可以根据具体的问题选择不同的模式和方法完成算法的设计。完全遍历法和不完全遍历法:在问题的解是有限离散解空间,且可以验证正确性和最优性时,最简单的算法就是把解空间的所有元素完全遍历一遍,逐个检测元素是否是我们要的解。这是最直接的算法,实现往往最简单。但是当解空间特别庞大时,这种算法很可能导致工程上无法承受的计算量。这时候可以利用不完全遍历方法——例如各种搜索法和规划法——来减少计算量。分治法:把一个问题分割成互相独立的多个部分分别求解的思路。这种求解思路带来的好处之一是便于进行并行计算。动态规划法:当问题的整体最优解就是由局部最优解组成的时候,经常采用的一种方法。贪心算法:常见的近似求解思路。当问题的整体最优解不是(或无法证明是)由局部最优解组成,且对解的最优性没有要求的时候,可以采用的一种方法。线性规划法:见条目。简并法:把一个问题通过逻辑或数学推理,简化成与之等价或者近似的、相对简单的模型,进而求解的方法。递归方法与迭代方法顺序计算、并行计算和分布式计算:顺序计算就是把形式化算法用编程语言进行单线程序列化后执行。确定性算法和非确定性算法精确求解和近似求解算法是计算机处理信息的本质,因为计算机程序本质上是一个算法来告诉计算机确切的步骤来执行一个指定的任务,如计算职工的薪水或打印学生的成绩单。一般地,当算法在处理信息时,会从输入设备或数据的存储地址读取数据,把结果写入输出设备或某个存储地址供以后再调用。算法的时间复杂度是指算法需要消耗的时间资源。一般来说,计算机算法是问题规模
n
{displaystyle n}
的函数
f
(
n
)
{displaystyle f(n)}
,算法的时间复杂度也因此记做算法执行时间的增长率与
f
(
n
)
{displaystyle f(n)}
的增长率正相关,称作渐近时间复杂度(英语:Asymptotic computational complexity),简称时间复杂度。常见的时间复杂度有:常数阶
O
(
1
)
{displaystyle O(1)}
,对数阶
O
(
log
n
)
{displaystyle O(log n)}
,线性阶
O
(
n
)
{displaystyle O(n)}
,线性对数阶
O
(
n
log
n
)
{displaystyle O(nlog n)}
,平方阶
O
(
n
2
)
{displaystyle O(n^{2})}
,立方阶
O
(
n
3
)
{displaystyle O(n^{3})}
,...,
k
{displaystyle k}
次方阶
O
(
n
k
)
{displaystyle O(n^{k})}
,指数阶
O
(
2
n
)
{displaystyle O(2^{n})}
。随着问题规模
n
{displaystyle n}
的不断增大,上述时间复杂度不断增大,算法的执行效率越低。算法的空间复杂度是指算法需要消耗的空间资源。其计算和表示方法与时间复杂度类似,一般都用复杂度的渐近性来表示。同时间复杂度相比,空间复杂度的分析要简单得多。算法不单单可以用计算机程序来实现,也可以在人工神经网络、电路或者机械设备上实现。这是算法的一个简单的例子。我们有一串随机数列。我们的目的是找到这个数列中最大的数。如果将数列中的每一个数字看成是一颗豆子的大小,可以将下面的算法形象地称为“捡豆子”:以上算法在中国大陆的教科书中通常被叫做“打擂法”或者“循环打擂”:在一个for循环中,每轮循环都有新的挑战者。若挑战者胜的话,挑战者做新擂主,否则擂主卫冕。for循环结束后输出最后的擂主。下面是一个形式算法,用ANSI C代码表示求两个自然数的最大公约数
设两个变量
M
{displaystyle M}
和
N
{displaystyle N}用ANSI C代码表示利用if函数以及递归则能做出更为精简的代码,更可省去交换的麻烦。(但是也因为递归调用,其空间复杂度提高)
相关
- 自体免疫缺乏免疫缺陷(英语:immunodeficiency)是指免疫系统抵抗传染病的能力失常或欠缺。免疫缺陷还可能降低肿瘤免疫监视功能。免疫缺陷多为继发性(secondary)免疫缺陷,不过也有些人生来就有
- 卫生署卫生福利部(简称卫福部)是中华民国有关公共卫生、医疗与社会福利事务的最高主管机关,同时监督各县市政府卫生与社会局(处)。其前身为1971年成立的“行政院卫生署”,2013年改制为部
- Mc5f14 6d10 7s2 7p3(预测)2, 8, 18, 32, 32, 18, 5(预测)主条目:镆的同位素镆(英文:Moscovium)是一种人工合成的化学元素,化学符号为Mc,原子序为115。它最早在俄国杜布纳联合原子核研究
- 胆据中医脏象学说,胆与、胃、小肠、大肠、膀胱、三焦合称“六腑”;与“肝”互为表里。主要功能为贮藏和排泄精汁(胆汁)、主决断和调节脏腑气机。胆与其他腑器不同之处,是不会和食物
- 陆陶文 ‧ 甲骨文 ‧ 金文 ‧ 古文 ‧ 石鼓文籀文 ‧ 鸟虫书 ‧ 篆书(大篆 ‧ 小篆)隶书 ‧ 楷书 ‧ 行书 ‧ 草书漆书 ‧ 书法 ‧ 飞白书笔画 ‧
- 衰变能量放射性或辐射性是指某元素的放射性同位素从不稳定的原子核自发地放出射线(如α射线、β射线、γ射线等)而衰变形成另一种同位素(衰变产物),这种现象称为放射性。衰变时放出的能量
- 翼龙见翼龙目的分类翼龙目(学名:Pterosauria),希腊文意思为“有翼的蜥蜴”,是一个飞行爬行动物的演化支。翼龙类生存于三叠纪晚期到白垩纪末期,约2亿1,600万年前到6,600万年前。翼龙类
- 中国酒文化饮酒是中国上古祭祀典礼之一,第一个造酒或发明酒的人已不可考,有仪狄与杜康两说,后世多将杜康尊为酒神,造酒业也奉杜康为祖师爷,在文学中杜康两字也成为酒的代名词。中国古代的酒
- 阿普林县阿普林县(英语:Appling County)是美国佐治亞州的一个县。2000年,人口有17,419人。根据2005年人口普查,人口估计有17,954人。 县政府所在地位于巴克斯利。阿普林县是以1812年战争
- 科塞尔阿尔布雷希特·科塞尔(Ludwig Karl Martin Leonhard Albrecht Kossel,1853年9月16日-1927年7月5日),生于罗斯托克,德国医生。科塞尔的工作范畴是生理化学,特别是组织和细胞的化学。