得到的结果如图!//1.做一个函数体static int F(int n) { int sum = 1; for (int i = 1; i <= n; i++) { sum *= i; } return sum; }主函数内写:int sum = 0; for (int i = 1; i <= 20; i++) { sum += F(i); Console.WriteLine(i + "积乘的和是:" + sum); } //Console.WriteLine(i+"积乘的和是:"+sum); Console.ReadKey();得到的结果如图!在网上找了好些代码,结果依然一样,求大神指点!
1 回答
慕妹3146593
TA贡献1820条经验 获得超9个赞
int所能表示的最大值为2147483647,而20!的结果超出了int所能表示最大值。因此,在计算阶乘时,采用long。代码如下:
| 123456789101112131415161718192021222324252627 | using System; class Program{ static void Main(string[] args) { long result = 0; for (int i = 1; i <= 20; i++) { long item = Factorial(i); Console.WriteLine("{0}!={1}", i, item); result += item; } Console.WriteLine("1!+2!+3!+...+20!={0}", result); Console.ReadKey(); } public static long Factorial(int n) { long r = 1; for (int i = 1; i <= n; i++) { r *= i; } return r; }} |
- 1 回答
- 0 关注
- 2018 浏览
添加回答
举报
0/150
提交
取消

