写了一个BBP算法的实现库,欢迎讨论

BBP 算法可以直接计算 π 的第 n 个十六进制数字,而无需计算前面的所有数字。

我的仓库:https://github.com/davelet/bbp


先来说说π这个老朋友吧。π,3.14159......,数学界的"网红",从古希腊的阿基米德开始,就有无数人试图用它丈量圆的秘密。为什么这么迷人?因为它是个无理数,十进制小数点后无限不循环,藏着无穷的奥秘。想象一下,你想知道π的第1000位是什么?传统方法呢?得从头算起,一位一位啃,像啃一根永不完的甘蔗,累不累啊?早年的数学家们用多边形逼近法,或者级数展开,比如莱布尼茨公式:π/4 = 1 - 1/3 + 1/5 - 1/7 + ...... 收敛得慢,算到几百位就得花好几天机时。更别提现代超级计算机了,算到万亿位也得从头来过。

不过1995年,一切都变了。那一年,加拿大数学家 Simon Plouffe 在玩一个叫PSLQ的整数关系发现算法时,意外挖到了金矿。他和 David Bailey、Jonathan Borwein 合作,发表了BBP公式(Bailey-Borwein-Plouffe公式)。

这公式一出,数学圈炸锅了!为什么?因为它允许你直接计算π的任意一位十六进制数字,而不用管前面的那些。

十六进制?对,就是我们电脑里常见的0-9和A-F那种。为什么用十六进制?因为公式设计得特别巧妙,和二进制、十六进制兼容,计算起来高效。

Plouffe当时用一台普通的电脑,就算出了π的第100万位------不是从头算,而是直奔那里!这感觉就像科幻小说里的"传送门",啪的一声,你就到目的地了。


我在仓库里提供了算法和项目的说明,欢迎大家讨论:README 读我

相关推荐
逻极21 小时前
变量与可变性:Rust中的数据绑定
开发语言·后端·rust
国服第二切图仔1 天前
Rust开发之Trait作为参数与返回值使用
开发语言·后端·rust
红尘散仙1 天前
TRNovel王者归来:让小说阅读"声"临其境的终端神器
前端·rust·ui kit
国服第二切图仔1 天前
Rust开发之使用 Trait 定义通用行为——实现形状面积计算系统
开发语言·网络·rust
程序员大雄学编程1 天前
用Python来学微积分22-费马定理
人工智能·python·数学·微积分
国服第二切图仔1 天前
Rust开发之使用match和if let处理Result错误
开发语言·网络·rust
国服第二切图仔1 天前
Rust开发之Result枚举与?运算符简化错误传播
开发语言·python·rust
国服第二切图仔1 天前
Rust开发之自定义错误类型(实现Error trait)
开发语言·python·rust
今日说"法"1 天前
Rust 内存泄漏的检测与防范:超越安全的实践指南
java·安全·rust
啊Q老师1 天前
Rust异步并发:业务落地的三个关键细节
rust·rust异步并发·业务落地的三个关键细节