精确计算PI小数点后800位小数

        近来,在网上发现一个能精确计算PI后面数百位的C程序,不敢独享,把其翻译成PASCAL版,供大家参考,该函数写的非常精巧,仅用了三行代码,就能精确计算出PI后800位小数。小弟不才,对数学造诣不深,不明白他算法的原理是什么,如果有懂的请不吝赐规教。下面将该函数的C版和PASCAL版一并贴出,供大家参考。 数据挖掘论坛

///////////////////////////////////////////////////////////
// C语言 源程序  功能:精确计算PI小数点后799位小数
// 转自 http://www.programfan.net/club/showbbs.asp?id=16434
//
//  #include <stdlib.h>
//  #include <stdio.h>
//  long a=10000,b,c=2800,d,e,f[2801],g;
//  main()
//  {
//    for(;b-c;) f[b++]=a/5;
//    for(;d=0,g=c*2;c-=14,printf("%.4d",e+d/a),e=d%a)
//      for(b=c;d+=f[b]*a,f[b]=d%--g,d/=g--,--b;d*=b);
//  }
///////////////////////////////////////////////////////////
// 版权所有,转载请注明出处
// 该C函数的 Delphi 版
// 编译: 黄涛  Hunter@Shentong.com.cn
//  2004-9-7
function CalcPI :string;
//long a=10000,b,c=2800,d,e,f[2801],g;
var a,b,c,d,e,g:integer;
    f :array[0..2800] of integer;
begin 数据挖掘工具
  a:=10000;b:=0;c:=2800;e:=0;f[2800]:=0;
  //for(;b-c;) f[b++]=a/5;
  while (b-c)<>0 do begin f[b]:= a div 5; inc(b) end;
  //for(;d=0,g=c*2;c-=14,printf("%.4d",e+d/a),e=d%a)
  while c<>0 do begin
    d:=0; g:=c*2; b:=c;
    repeat                                 
      //for(b=c;d+=f[b]*a,f[b]=d%--g,d/=g--,--b;d*=b);
      d:=d+f[b]*a;dec(g);f[b]:=d mod g;
      d:=d div g;dec(g);dec(b);
      if b<>0 then d:=d*b;
    until b=0;
    c:=c-14;
    Result:= Result + format("%.4d",[e+ d div a]);
    e:=d mod a;
  end;
end; 数据挖掘研究院

     通过上面的代码可以看出,C语言非常灵活,写出的代码的确很精练,不过他的编程风格确实不值得提倡,太难懂了,非C语言高手很难搞懂他写的什么。不过如果有谁也能写出更精练的Delphi代码也请贴出,供大家学习。我写的只是为了翻译,基本上是一一对应的,没有做更多的优化。 数据挖掘工具


[数据挖掘专家] [数据挖掘研究院] [数据挖掘论坛] [数据挖掘实验室]
上一篇:Command程序示例,可以带参数运行
下一篇:组件制作之二(一个简单组件的制作过程)
最新评论共有 0 位网友发表了评论 , 查看所有评论
发表评论( 不能超过250字,需审核,请自觉遵守互联网相关政策法规。 )
匿名?
数据挖掘网站导航 数据挖掘论坛导航
  • 数据挖掘工具
  • 数据挖掘论坛
  • DataCruncher - Cognos
  • MineSet - MathSoft
  • Intelligent Miner - GainSmarts
  • Sqlserver - SAS - Clementine
  • CART - Weka - WizSoft
  • NeuroShell - ModelQuest
  • data mining tools - Darwin
  • 数据挖掘交友
  • 数据挖掘博客
  • 数据挖掘工具
  • 数据挖掘资源
  • 数据挖掘技术算法
  • 数据挖掘相关期刊、会议
  • 研究院联盟合作专区
  • 数据挖掘基础与相关技术
  • 数据挖掘厂商与就业
  • 数据挖掘研究者乐园
  • 知名厂商数据挖掘工具资料
  • 国内数据挖掘实验室
  • Foreign Data Mining Lab
  • 热点关注
  • GDI+简介
  • COM与DCOM的区别与联系
  • 使用Delphi解析XML 文档
  • 如何设置delphi/cbuilder/BDE/MSSQL
  • BORLAND在“迫害”程序员?
  • 将image的图片保存为JPG格式图片方法
  • InstallShieldExpressfordelphi制作安装程
  • Real Programmers Use Pascal
  • 关于在COM中使用可选参数的研究
  • TStrings的AddObject方法应用
  • 论坛最新话题
  • Foundations of Statistical Natural Langu
  • Game Theory meet Data Mining: A Recent P
  • System Building: How does it help or hin
  • 数据挖掘与Clementine培训
  • 新手报到
  • 求 SASEM 客户流失预测分析
  • 数据挖掘工程师/搜索研究院—北京——无线
  • 数据挖掘入门介绍(如何着手数据挖掘)
  • Information Overload Survey Results
  • The INEX 2005 Workshop on Element Retrie
  • 相关资讯
  • BORLAND在“迫害”程序员?
  • 李维:我的回忆和一些有趣的事(精彩绝伦)
  • 李维看.net和DELPHI6(含李维照片)
  • 《代码大全》电子版1.01发布了
  • Real Programmers Use Pascal
  • Kylix安装手记
  • Borland与Microsoft关于Delphi的对话
  • InstallShieldExpressfordelphi制作安装程
  • 关于在COM中使用可选参数的研究
  • msagent经典用法
  • 数据挖掘实验室资料
  • 数据挖掘博客地址
  • 数据挖掘实验室网站地址
  • Prepare for Medicare audits by using dat
  • 注册成为SAS用户与爱好者俱乐部会员
  • 水南梅
  • 明日烟
  • 新人报道
  • 下载
  • 厦门服务器托管,450元/月—0592-5177319 高
  • 买空间送域名--0592-5177319 高静