青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

XGuru's Blog

技術,是一種態度。關注:高性能后端技術/服務器架構/C++/C/LAMP

   :: 首頁 :: 聯系 :: 聚合  :: 管理
  20 Posts :: 0 Stories :: 93 Comments :: 0 Trackbacks

公告





twitter / xoXGuru

feedsky
抓虾
google reader
鲜果
QQ邮箱
九点

常用鏈接

留言簿(12)

搜索

  •  

最新評論

閱讀排行榜

by Xguru

 又說階乘,這是老生常談了吧。想都不用想,一個遞歸輕松搞定!

int factorial(int n)
{
    
if( n == 1)
        
return 1;
    
return n * factorial(n-1);
}

或者你覺得遞歸效率沒有尾遞歸來的好 ,大筆一揮。

long fact_iter(long product, long counter, long maxcount) 
{      
  
return (counter > maxcount) ? product : fact_iter(product*counter, counter+1, maxcount);
}
      

long factorial(long n) 
{
  
return fact_iter(11, n);    
}

 
         或者你看過《代碼大全》上面說過:“如果為我工作的程序員用遞歸去計算階乘那么我寧愿換人。”
使用遞歸求階乘速度緩慢,無法預測運行期間內存使用情況,難以理解。于是你把遞歸改成了循環語句。

int factorial(int n)
{
    
int result = 1;
    
for(int i = 2 ; i <= n; i++)
    
{
        result 
= result * i;
    }

    
return result;
}
          當你寫下這些代碼的時候,會不會覺得少了些什么?

          在我的32位環境上測試一下,計算到33!的時候的溢出了,于是你會說,這是int的值太小了嘛,于是你換了個long double,測試一下,什么玩意嘛這是,數再大一點的話也不行了

         
 那就改用鏈表或者數組表示吧,鏈表的速度就太慢了,用數組吧。

int factorial2(int n,int a[])

    
int carry;
    
int digit = 1;
    a[
0= 1;
    
int temp;
    
for(int i = 2; i <= n; ++i)
    
{
        
for(int j = 1, carry = 0; j <= digit; ++j)    
        
{
            temp 
= a[j-1* i + carry;
            a[j
-1= temp % 10;
            carry 
= temp / 10;
        }

        
while(carry) 
        
{
            a[
++digit-1= carry % 10;
            carry 
/= 10;
        }

    }

    
return --digit;
}

        這個算法模擬手工計算的過程,將結果保存在a數組中,返回的是結果的位數

       你在這個時候是不是感覺輕飄飄了呢?請暫時打住。

        如果我要求一個
10W以上大數的一個科學計數法的表達式呢?或者是問你,10W 級別上的N!左邊第三位的數字是多少?呃,這個是數學家的事了吧?振作精神,來挑戰自我吧!真正的程序員需要的就是這種追根究底的精神。
        來試試數學分析方法,James Stirling這位蘇格蘭數學家,280多年前就給出了這個極限式子

                                     

       這個式子能用極快的速度求出n!的近似值,也可以使用它來無限接近準確結果。具體的介紹和證明過程在這里 或者 這里

斯特靈級數公式



      下面的代碼是求大數N!科學計數法表示

struct bigNum 
{
       
double n; //尾數
       int    e; //指數
}
;
void factorial3(struct bigNum *p,int n)
{
       
double logx,s,item;//s:級數的和  item:級數的每一項
       int i;
       logx 
= n* log10((double)n/E);
       p
->= (int)(logx);   p->n= pow(10.0, logx-p->e);
       p
->*= sqrt( 2* PI* (double)n);
       
for (item=1.0,s=0.0,i=0;i<sizeof(a1)/sizeof(double);i++)
       
{
              s 
+= item * a1[i];
              item 
/= (double)n;
       }

       p
->*=s;
}

 

      下面這個是階乘的對數的漸近展開式
               

void factorial3b(struct bigNum *p,int n)
{
    
double logR;
    
double s,item;
    
int i;
    logR
=0.5*log(2.0*PI)+((double)n+0.5)*log(n)-(double)n;
    
    
for (item=1/(double)n,s=0.0,i=0;i<sizeof(a2)/sizeof(double);i++)
    
{
        s
+= item * a2[i];
        item 
/= (double)(n)* (double)n; 
    }

    logR
+=s;
    p
->= (int)( logR / log(10));//換底公式
    p->= pow(10.00, logR/log(10- p->e);
}

       要是求階層的位數也是特別簡單

double getFactorialLength(int n)
{
    
return (n * log(double(n)) - n + 0.5 * log(2.0 * n * PI )) / log(10.0)+1;
}

       這個求出來的是位數的近似數,或者是改進一下,使用ceil函數來求出不小于給定實數的最小整數。

int getFactorialLength(int n)
{
    
if( n == 1 )
        
return 1;
    
else
    
return (int)ceil((N*log(N)-N+log(2*N*PI)/2)/log(10));
}


到此,你會不由感嘆:計算機科學中最閃光,最精髓,最本質的東西還是數學



芒德布羅集合的邊界
最后用羅素的話結束這篇隨筆:
       Mathematics, rightly viewed, possesses not only truth, but supreme beauty — a beauty cold and austere, like that of sculpture, without appeal to any part of our weaker nature, without the gorgeous trappings of painting or music, yet sublimely pure, and capable of a stern perfection such as only the greatest art can show. The true spirit of delight, the exaltation, the sense of being more than Man, which is the touchstone of the highest excellence, is to be found in mathematics as surely as poetry.

 

參考資料
1.Tom M. Apostol.《數學分析, 微積分》(Mathematical Analysis)
2.Steve McConnell.《代碼大全(第二版)》(CODE COMPLETE, Second Edition)
3.http://en.wikipedia.org/wiki/Stirling_approximation#History

4.
http://mathworld.wolfram.com/StirlingsApproximation.html

5.
http://zh.straightworldbank.com/wiki/%E6%96%AF%E7%89%B9%E6%9E%97%E5%85%AC%E5%BC%8F

 

posted on 2009-12-30 19:02 XGuru 閱讀(1938) 評論(4)  編輯 收藏 引用

Feedback

# re: 雜感系列之二--階乘算法雜感 2009-12-30 22:55 NighCrawler
最后的那張分形幾何圖是軟件生成的?  回復  更多評論
  

# re: 雜感系列之二--階乘算法雜感 2010-01-05 18:24 argmax
Stirling公式只是一個近似,當n較大時才比較接近原始的結果。  回復  更多評論
  

# re: 雜感系列之二--階乘算法雜感[未登錄] 2010-04-02 17:34 Mingle
文章中的數學公式是如何書寫的?  回復  更多評論
  

# re: 雜感系列之二--階乘算法雜感[未登錄] 2010-04-06 22:37 xguru
@Mingle
latex公式常用宏包 http://www.ctex.org/documents/packages/math/index.htm

還有 word2007的公式生成也不錯呢
  回復  更多評論
  


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美69视频| 国产精品久久久久91| 在线精品视频一区二区| 久久免费国产精品1| 欧美制服丝袜| 亚洲国产综合视频在线观看| 欧美激情精品久久久久久久变态| 欧美jizz19性欧美| 日韩视频在线一区二区三区| 亚洲激情av在线| 欧美日韩免费在线| 亚洲欧美国产va在线影院| 亚洲小说春色综合另类电影| 国产日韩欧美91| 欧美一区免费视频| 久久久美女艺术照精彩视频福利播放 | 亚洲一级二级| 欧美一区二区三区视频在线| 国产一区二区三区高清在线观看| 老司机精品视频一区二区三区| 麻豆精品91| 一区二区三区日韩| 亚洲欧美日韩国产精品| 伊人精品成人久久综合软件| 亚洲国产欧美不卡在线观看| 欧美视频在线播放| 久久天堂精品| 免费影视亚洲| 欧美日韩国产二区| 久久九九全国免费精品观看| 久热综合在线亚洲精品| 亚洲自啪免费| 欧美成人自拍视频| 久久久久久噜噜噜久久久精品| 免费成人毛片| 久久精品中文字幕一区二区三区| 欧美成人精品一区二区| 久久国产成人| 欧美片在线观看| 免费日韩成人| 国产亚洲精品bt天堂精选| 亚洲美女精品成人在线视频| 美女主播一区| 久久激情五月婷婷| 欧美日韩精品中文字幕| 久热爱精品视频线路一| 国产精品福利av| 亚洲日本欧美天堂| 亚洲国产精品黑人久久久| 午夜精品久久久久久99热软件| 99re亚洲国产精品| 欧美mv日韩mv国产网站| 老牛国产精品一区的观看方式| 国产精品免费区二区三区观看| 91久久久在线| 亚洲伦伦在线| 欧美freesex8一10精品| 欧美黄色精品| 亚洲动漫精品| 久久视频一区二区| 老司机成人网| 在线观看国产成人av片| 久久精品国产成人| 久久免费少妇高潮久久精品99| 国产麻豆午夜三级精品| 亚洲视频中文| 欧美在线播放视频| 国产三区精品| 欧美一区二区黄色| 久久国产婷婷国产香蕉| 国产日韩欧美高清| 欧美亚洲综合另类| 久久久免费av| 亚洲国产精品激情在线观看| 美女日韩在线中文字幕| 亚洲电影免费| 一区二区三区四区五区视频| 欧美日韩精品是欧美日韩精品| 日韩一级免费观看| 亚洲欧美日韩人成在线播放| 国产精品久久久久久影视| 亚洲影院一区| 久久综合伊人77777麻豆| 在线欧美福利| 欧美日韩国产小视频在线观看| 国产精品99久久久久久久女警| 欧美一区二区三区电影在线观看| 国产欧亚日韩视频| 久久精品盗摄| 最新国产成人在线观看| 亚洲香蕉网站| 国产一区在线免费观看| 麻豆精品传媒视频| 中文精品视频| 美女久久网站| 亚洲私人影吧| 在线播放中文字幕一区| 欧美日韩精品欧美日韩精品一| 亚洲午夜在线观看| 免费在线亚洲| 亚洲图片激情小说| 经典三级久久| 国产精品久久久久av| 久久久噜噜噜久噜久久| 亚洲精品少妇30p| 久久久精品国产一区二区三区 | 欧美国产欧美亚洲国产日韩mv天天看完整 | av不卡免费看| 国产主播喷水一区二区| 欧美另类专区| 久久频这里精品99香蕉| 中日韩视频在线观看| 欧美顶级艳妇交换群宴| 久久国产视频网| 在线中文字幕日韩| 亚洲国产欧美精品| 国产日本欧美一区二区| 欧美日韩午夜视频在线观看| 久久久国产午夜精品| 亚洲综合久久久久| 99精品热视频只有精品10| 美玉足脚交一区二区三区图片| 亚洲欧美美女| 亚洲视频欧美视频| 日韩午夜激情| 亚洲青涩在线| 亚洲电影激情视频网站| 国产亚洲一区在线| 国产精品久久久久毛片软件| 欧美激情第一页xxx| 久久久久久高潮国产精品视| 亚洲男同1069视频| 一区二区三区|亚洲午夜| 亚洲成色www8888| 麻豆精品在线观看| 卡通动漫国产精品| 久久精品理论片| 久久精品色图| 久久乐国产精品| 久久精品三级| 久久在线视频在线| 美女免费视频一区| 能在线观看的日韩av| 美国十次成人| 免费看精品久久片| 麻豆成人在线观看| 欧美国产精品一区| 亚洲电影免费观看高清完整版在线观看| 久热爱精品视频线路一| 免费在线成人| 亚洲人成网站777色婷婷| 最近中文字幕日韩精品| 日韩手机在线导航| 亚洲视频一区二区在线观看| 亚洲一区精彩视频| 欧美在线视频免费播放| 久久综合九色| 欧美大片免费观看| 欧美三级网址| 国产一区深夜福利| 亚洲国产三级在线| 中文欧美字幕免费| 欧美一级久久久| 久久在线免费观看视频| 欧美高清成人| 亚洲毛片播放| 欧美一区二区三区婷婷月色| 久久久久久久综合狠狠综合| 欧美fxxxxxx另类| 国产精品久久久久77777| 国内精品久久久久久久影视麻豆 | 亚洲一区二区高清| 久久成人一区二区| 欧美国产1区2区| 一区二区三区产品免费精品久久75| 亚洲影院免费| 免费成年人欧美视频| 欧美视频一区在线| 狠狠色噜噜狠狠狠狠色吗综合| 亚洲狼人综合| 久久aⅴ乱码一区二区三区| 欧美+日本+国产+在线a∨观看| 亚洲伦理自拍| 久久久久久久一区二区三区| 欧美日韩成人综合| 激情六月综合| 亚洲欧美国产77777| 欧美福利视频在线| 亚洲一区二区三区免费在线观看| 久久黄色级2电影| 欧美色欧美亚洲另类二区| 精品福利免费观看| 午夜在线一区二区| 亚洲欧洲在线视频| 久久久国产精品一区二区三区| 欧美涩涩网站| 亚洲精品一区二区三区不| 久久漫画官网| 亚洲午夜精品17c| 欧美日本一区|