Skip to content

搞英语 → 看世界

翻译英文优质信息和名人推特

Menu
  • 首页
  • 作者列表
  • 独立博客
  • 专业媒体
  • 名人推特
  • 邮件列表
  • 关于本站
Menu

欧几里德算法的运行时间分布

Posted on 2025-04-28

当您为算法提供一对连续的斐波那契数时,欧几里德算法的最坏情况运行时间就会发生。该算法需要n步来计算F n +1和F n +2的最大公约数。

第 n个斐波那契数是最接近 φ n /√5 的整数,其中 φ = (1 + √5)/2 是黄金比例。您可以取对数并求解最大的n ,使得F n小于x ,减去 2 ,并确定找到小于x的两个数字的 gcd 所需步骤数的上限。

但是平均运行时间或运行时间的分布又如何呢?

对于较大的x ,使用欧几里德算法计算两个数字 0 < a < b < x的 gcd 所需的步数分布近似正态分布

12 log(2) log( b ) / π²。

例如,参见[1]。

让我们通过模拟来说明这一点。下面的 Python 代码返回计算 gcd( a , b ) 时使用的步数。

 def 欧几里德(a, b):         步骤 = 0         而a!= 0:             a、b = b%a、a             步骤 += 1         返回步骤 # gcd = b 

我生成了 10,000 对小于 2 63的随机整数(因为最大有符号 64 位整数为 2 63 − 1),并绘制了运行时间的直方图。

euclidean_algorithm.png

我得到了一条漂亮的钟形曲线,平均值为 36.3736。理论平均值为 0.8428 log(2 63 ) = 36.8021。

[1] 道格·汉斯利。欧几里得算法的步骤数。数论杂志 49。142–182 (1994)。

欧几里得算法的运行时间分布一文首次出现在John D. Cook上。

原文: https://www.johndcook.com/blog/2025/04/27/euclidean-algorithm-runtime/

本站文章系自动翻译,站长会周期检查,如果有不当内容,请点此留言,非常感谢。
  • Abhinav
  • Abigail Pain
  • Adam Fortuna
  • Alberto Gallego
  • Alex Wlchan
  • Answer.AI
  • Arne Bahlo
  • Ben Carlson
  • Ben Kuhn
  • Bert Hubert
  • Bits about Money
  • Brian Krebs
  • ByteByteGo
  • Chip Huyen
  • Chips and Cheese
  • Christopher Butler
  • Colin Percival
  • Cool Infographics
  • Dan Sinker
  • David Walsh
  • Dmitry Dolzhenko
  • Dustin Curtis
  • Elad Gil
  • Ellie Huxtable
  • Ethan Marcotte
  • Exponential View
  • FAIL Blog
  • Founder Weekly
  • Geoffrey Huntley
  • Geoffrey Litt
  • Greg Mankiw
  • Henrique Dias
  • Hypercritical
  • IEEE Spectrum
  • Investment Talk
  • Jaz
  • Jeff Geerling
  • Jonas Hietala
  • Josh Comeau
  • Lenny Rachitsky
  • Liz Danzico
  • Lou Plummer
  • Luke Wroblewski
  • Matt Baer
  • Matt Stoller
  • Matthias Endler
  • Mert Bulan
  • Mostly metrics
  • News Letter
  • NextDraft
  • Non_Interactive
  • Not Boring
  • One Useful Thing
  • Phil Eaton
  • Product Market Fit
  • Readwise
  • ReedyBear
  • Robert Heaton
  • Ruben Schade
  • Sage Economics
  • Sam Altman
  • Sam Rose
  • selfh.st
  • Shtetl-Optimized
  • Simon schreibt
  • Slashdot
  • Small Good Things
  • Taylor Troesh
  • Telegram Blog
  • The Macro Compass
  • The Pomp Letter
  • thesephist
  • Thinking Deep & Wide
  • Tim Kellogg
  • Understanding AI
  • 英文媒体
  • 英文推特
  • 英文独立博客
©2025 搞英语 → 看世界 | Design: Newspaperly WordPress Theme