解题思路:


注意事项:


参考代码:

#include<stdio.h>
int main()
{
                //num[]数组代表结果,用于计算; res代表进位; len代表计算结果的长度
	int num[100000] = { 1 }, i, j, res = 0, len = 1;
	for (i = 1; i <=1977; i++)
	{                                      //从 1 乘到 1977
		res = 0;
		for (j = 0; j < len; j++)          //对数组的每一个非0数,进行乘法
		{
			num[j] = num[j] * i + res;   //数组的每一位记得加进位数
			if (num[j] > 10)
			{
				res = num[j] / 10;        //如果数组的某一位超过10,进位
				num[j] %= 10;
				if (j == len - 1)        //如果数组的最高位也存在进位,则结果len加一
					len++;
			}
			else
				res = 0;
		}
	}
	for (i = len - 1; i >= 0; i--)            //倒序输出结果
		printf("%d", num[i]);
	return 0;

}


点赞(5)
 

0.0分

2 人评分

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

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

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

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

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

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

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

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

评论列表 共有 1 条评论

zhangyuxuan 3月前 回复TA
我的天哪,你写的也太好了吧!!!!!!!!!大师,我悟了,这一刻是心灵的净化!!!!!!!!!