解题思路: 注意事项: 参考代码: #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 人评分
C语言训练-排序问题<1> (C++代码)浏览:595 |
C语言训练-自由落体问题 (C语言代码)浏览:1736 |
矩阵乘法 (C++代码)浏览:1460 |
C语言训练-阶乘和数* (C语言代码)-------- 呆板写法浏览:1351 |
求组合数 (C语言代码)浏览:1154 |
WU-蓝桥杯算法提高VIP-交换Easy (C++代码)浏览:1113 |
C语言程序设计教程(第三版)课后习题8.8 (C语言代码)浏览:534 |
1024题解浏览:806 |
C语言程序设计教程(第三版)课后习题10.5 (C语言代码)浏览:535 |
字符串比较 (C语言代码)浏览:681 |