久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

專注電子技術(shù)學(xué)習(xí)與研究
當(dāng)前位置:單片機(jī)教程網(wǎng) >> MCU設(shè)計(jì)實(shí)例 >> 瀏覽文章

高精度階乘小程序

作者:佚名   來源:本站原創(chuàng)   點(diǎn)擊數(shù):  更新時(shí)間:2009年12月04日   【字體:

#include "Stdio.h"
#include "Conio.h"
int main(void)
{
    int nums[10000]; /*nums數(shù)組越大,且改變?yōu)殚L整型,可計(jì)算更大的階乘,但改變數(shù)組類型會(huì)變慢*/
    int k,j;
    int n,i;
    printf("Please input a integer n:");
    scanf("%d",&n);
    for(i=1;i<=n-1;i++) nums[i]=0; /*這里有改進(jìn)的余地*/
    nums[0]=1;
    k=0;
    for(i=2;i<=n;i++)
    {
        for(j=0;j<=k;j++) nums[j]=nums[j]*i;
        for(j=0;j<=k-1;j++)
        {
            nums[j+1]=nums[j+1]+(int)(nums[j]/10); /*進(jìn)位計(jì)算*/
            nums[j]=nums[j]%10;
        }
        while(nums[k]>=10)
        {
            nums[k+1]=nums[k+1]+(int)(nums[k]/10); /*把結(jié)果數(shù)字的最高位分別放進(jìn)nums數(shù)組中對應(yīng)的位中,也可改進(jìn)*/
            nums[k]=nums[k]%10;
            k++;
        }
    }
    printf("\nn!=");
    for(i=k;i>=0;i--) printf("%d",nums[i]); /*輸出結(jié)果*/
    printf("\nk=%d",k+1);  /*k+1是最后結(jié)果的位數(shù)*/
    getch();
    return 0;
}

這個(gè)小程序根據(jù)整數(shù)乘法的原理,可突破計(jì)算機(jī)本身及編程語言存儲(chǔ)類型大小限制,計(jì)算高精度的階乘,如果nums數(shù)組大小為10000,大概可以計(jì)算3000的階乘,即3000!,3000!計(jì)算的最后結(jié)果數(shù)字是9155位,其實(shí)這個(gè)程序還有很多可以改進(jìn)的地方,初用C語言,沒有把C語言的一些優(yōu)勢發(fā)揮出來。還有,我在VB里寫好后運(yùn)行測試發(fā)現(xiàn)和C語言比,在這算法一樣的情況下,效率是天差地別的!
本程序在TC2.0下編譯通過!
(還有,標(biāo)顏色標(biāo)得我手軟了!)

關(guān)閉窗口

相關(guān)文章

主站蜘蛛池模板: 精品影院 | 国产高清精品一区二区三区 | 久久综合888| 成人精品一区二区三区 | 日日夜夜狠狠操 | 性色av一区 | 欧美国产一区二区三区 | 亚洲国产一区二区三区 | 国产激情一区二区三区 | 91黄色片免费看 | 国产精品久久久久久久久久 | 亚洲国产精品人人爽夜夜爽 | 亚洲一区二区三区国产 | 日韩免费| 久久不卡视频 | 成在线人视频免费视频 | 免费亚洲一区二区 | www久| 日本成人中文字幕 | 综合国产第二页 | 草草网| 精品一区二区三区在线观看国产 | 操操日| 中文久久 | 久久久成人网 | 中文字幕在线电影观看 | 亚洲一区二区三区四区在线观看 | 亚洲视频中文字幕 | 91在线看片| 成人av观看 | 亚洲精品一区二区三区免 | 成人国产精品久久 | 国产成人99久久亚洲综合精品 | 国产精品a一区二区三区网址 | 日本一道本视频 | 国产欧美一区二区三区久久手机版 | 成人网av| 毛片网站在线观看 | 狠狠插天天干 | 国产97人人超碰caoprom | 久久av在线播放 |