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

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 閱讀(1943) 評論(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>
            中文欧美字幕免费| 日韩视频永久免费| 性色av一区二区三区红粉影视| 欧美激情亚洲另类| 欧美ed2k| 一区二区冒白浆视频| 亚洲精品久久久久| 国产精品v欧美精品v日韩| 亚洲男人av电影| 久久国产精品电影| 亚洲日本中文字幕免费在线不卡| 91久久久久久久久久久久久| 欧美日韩国产丝袜另类| 午夜精品一区二区三区在线视| 亚洲影音先锋| 在线看日韩av| 日韩视频一区二区| 国产欧美一区二区精品性色| 母乳一区在线观看| 欧美日韩国产限制| 久久全球大尺度高清视频| 老司机午夜精品视频| 欧美在线视频在线播放完整版免费观看| 国产一区二区三区在线观看视频| 免费成人黄色片| 欧美视频中文字幕在线| 久久国产色av| 欧美日韩岛国| 六十路精品视频| 国产精品高清在线| 欧美成人黄色小视频| 欧美午夜电影在线| 欧美激情无毛| 国产亚洲aⅴaaaaaa毛片| 亚洲韩国青草视频| 狠狠做深爱婷婷久久综合一区 | 国产欧美日韩| 欧美黄色影院| 国产日韩欧美精品| 99精品国产热久久91蜜凸| 一区在线免费| 亚洲欧美国产精品va在线观看 | 国产精品一区二区a| 亚洲国产一区二区a毛片| 国产视频一区三区| 日韩一级黄色大片| 亚洲精品小视频在线观看| 欧美一区二区三区日韩| 在线一区二区三区做爰视频网站| 久久久人人人| 久久久久综合网| 国产精品爽黄69| 亚洲免费久久| 日韩视频在线观看国产| 久久综合九色九九| 美女精品网站| 国内成人精品2018免费看| 亚洲一区二区三区四区五区午夜| 99日韩精品| 欧美激情精品久久久久久蜜臀| 模特精品在线| 亚洲激情成人| 欧美不卡在线视频| 亚洲国产日韩欧美| 亚洲精品久久嫩草网站秘色| 老巨人导航500精品| 蜜桃精品久久久久久久免费影院| 国产一区二区中文字幕免费看| 宅男精品视频| 欧美一区二区三区免费视| 国产精品久久一级| 亚洲欧美综合v| 久久免费观看视频| 在线日韩av永久免费观看| 久久综合影视| 91久久久精品| 亚洲欧美日韩一区二区| 国产精品每日更新| 欧美一区=区| 麻豆精品精品国产自在97香蕉| 136国产福利精品导航网址| 狂野欧美一区| 日韩一本二本av| 欧美在线观看天堂一区二区三区| 国产日韩欧美综合精品| 久久国内精品自在自线400部| 免费在线观看精品| 99精品国产热久久91蜜凸| 国产精品二区影院| 欧美中文字幕精品| 亚洲国产欧美一区二区三区同亚洲| 国产精品99久久不卡二区 | 久久人人超碰| 亚洲国产精品成人综合| 国产精品99久久久久久人| 国产精品久久午夜| 久久深夜福利| 中日韩美女免费视频网址在线观看| 欧美综合国产精品久久丁香| 在线观看日韩精品| 国产精品扒开腿爽爽爽视频| 久久激情网站| 99精品免费视频| 老司机精品福利视频| 亚洲色在线视频| 一色屋精品视频在线看| 欧美日韩在线一区| 久久蜜桃资源一区二区老牛 | 欧美与欧洲交xxxx免费观看| 在线成人av网站| 欧美三日本三级少妇三2023| 久久久av水蜜桃| 亚洲午夜一区二区| 亚洲国产精品成人| 久久深夜福利免费观看| 一区二区三区欧美日韩| 在线观看欧美精品| 国产乱码精品一区二区三区不卡 | 亚洲精品欧美日韩| 久久免费偷拍视频| 午夜精品三级视频福利| 99国产精品久久久久老师| 国产一区二区三区在线免费观看| 欧美精品综合| 免费看精品久久片| 久久久久**毛片大全| 亚洲综合色视频| 日韩亚洲欧美一区| 亚洲日本aⅴ片在线观看香蕉| 葵司免费一区二区三区四区五区| 亚洲男女自偷自拍图片另类| 99成人免费视频| 亚洲精品国精品久久99热一| 激情久久久久久久久久久久久久久久| 欧美视频在线观看免费网址| 欧美精品亚洲| 欧美激情一二区| 欧美激情bt| 欧美激情亚洲| 欧美日韩视频在线第一区| 欧美顶级大胆免费视频| 免费成人高清在线视频| 久久久亚洲精品一区二区三区| 欧美在线观看视频| 久久aⅴ乱码一区二区三区| 午夜视频在线观看一区| 欧美一区二区视频网站| 欧美在线啊v| 久久久精品五月天| 久久午夜av| 欧美国产欧美亚州国产日韩mv天天看完整| 久久婷婷国产综合尤物精品 | 亚洲黄一区二区三区| 欧美高清在线一区二区| 欧美高清在线视频| 91久久精品国产91性色tv| 亚洲欧洲中文日韩久久av乱码| 亚洲国产精品v| 亚洲美女毛片| 亚洲一区三区电影在线观看| 亚洲女女女同性video| 欧美在线观看视频一区二区三区| 欧美亚洲一区在线| 久久一区二区三区av| 欧美电影免费观看| 欧美午夜电影在线观看| 国产亚洲精品7777| 亚洲黄网站黄| 亚洲一区二区免费看| 午夜激情综合网| 免费不卡在线观看av| 91久久精品美女| 亚洲欧美日韩另类| 欧美jizz19hd性欧美| 国产精品九九久久久久久久| 国产一区二区三区免费观看| 亚洲精品黄色| 欧美亚洲一区二区三区| 欧美福利网址| 亚洲综合清纯丝袜自拍| 玖玖在线精品| 国产精品视频一区二区三区| 在线观看一区欧美| 亚洲免费一在线| 欧美不卡三区| 亚洲一区二区视频在线| 麻豆精品一区二区综合av| 国产精品久久久久久久浪潮网站| 精品成人国产| 亚洲专区一区二区三区| 欧美mv日韩mv国产网站| 亚洲愉拍自拍另类高清精品| 欧美成在线观看| 国产一区视频在线观看免费| 制服诱惑一区二区| 欧美成人精品一区二区| 香蕉久久精品日日躁夜夜躁| 欧美日韩一二区| 91久久黄色| 男人的天堂亚洲|