正弦


私信TA

用户名:qq15582632151

访问量:30566

签 名:

等  级
排  名 143
经  验 7159
参赛次数 0
文章发表 57
年  龄 0
在职情况 学生
学  校 小学生
专  业

  自我简介:

TA的其他文章

解题思路:


注意事项:


参考代码:

#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;

}


 

0.0分

1 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区