得到的结果如图!//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 关注
- 1935 浏览
添加回答
举报
0/150
提交
取消