解题思路: 注意事项: 参考代码: #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 人评分
简洁的代码浏览:1409 |
简单的a+b (C语言代码)浏览:629 |
C语言程序设计教程(第三版)课后习题7.4 (C语言代码)浏览:608 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:617 |
数组输出 (C语言代码)--此题的题目描述有问题浏览:1817 |
C语言程序设计教程(第三版)课后习题6.10 (C语言代码)浏览:756 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:867 |
C语言程序设计教程(第三版)课后习题5.7 (Java代码)浏览:889 |
三角形 (C语言代码)浏览:915 |
K-进制数 (C语言描述,蓝桥杯)浏览:925 |