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

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

高精度階乘小程序

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

#include "Stdio.h"
#include "Conio.h"
int main(void)
{
    int nums[10000]; /*nums數(shù)組越大,且改變?yōu)殚L整型,可計算更大的階乘,但改變數(shù)組類型會變慢*/
    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; /*這里有改進的余地*/
    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); /*進位計算*/
            nums[j]=nums[j]%10;
        }
        while(nums[k]>=10)
        {
            nums[k+1]=nums[k+1]+(int)(nums[k]/10); /*把結(jié)果數(shù)字的最高位分別放進nums數(shù)組中對應(yīng)的位中,也可改進*/
            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;
}

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

關(guān)閉窗口

相關(guān)文章

主站蜘蛛池模板: 17c在线 | 性欧美bbw | 亚洲一级免费视频 | 亚洲高清视频在线观看 | 欧美一区二区三 | 中文字幕日韩高清 | 狠狠干伊人 | 久久久久久久久久久国产 | 黄色小视频在线播放 | 亚洲福利网站 | 成年人视频网站 | 国产精品久久久久久中文字 | 日本国产在线 | a在线免费观看 | 日韩不卡一区二区 | 欧美国产综合 | 美国特色黄a大片 | 91在线播放视频 | 一级做a爱片性色毛片 | 欧美日韩国产在线 | 91亚洲国产成人久久精品网站 | 国产乱码精品一区二区三 | 一区二区高清视频 | 日本一级黄色 | 亚洲黄色免费 | 亚洲欧美在线视频 | a级片免费| 亚洲欧美视频在线观看 | 久久人体视频 | 精品福利一区 | 久久精视频 | 伊人久久网站 | 欧美专区在线观看 | 一级毛片久久久 | 欧美日韩国产在线 | 无套内谢的新婚少妇国语播放 | 成年免费视频黄网站在线观看 | av一区二区三区 | 成人免费av| 国产欧美精品一区二区 | 91麻豆精品视频 |