解题思路: 注意事项: 参考代码: #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分
2 人评分