解题思路:
数组存储大数,求结果占数组多少位,将数组输出。
注意事项:
掌握数组存储大数的方法。
参考代码:

#include<stdio.h>

int main()

{

int N[6000]={0};

N[0]=7;N[1]=7;N[2]=9;N[3]=1;//为方便往高位进位倒着输入

for(int i=1976;i>0;i--)

{

    for(int j=0;j<6000;j++)//数组每位进行阶乘运算

    {

        N[j]=N[j]*i;

    }

    for(int k=0;k<5999;k++)//数组进位

    {

       if(N[k]>9)

       {

            N[k+1]=N[k+1]+N[k]/10;

           N[k]=N[k]%10;

       }

    }

}

int m=5999;

while(N[m]==0)//获取最高位数的下标

{

m--;

}


    for(int l=m;l>=0;l--)

    {

        printf("%d",N[l]);

    }

    return 0;

}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论