发布网友 发布时间:2024-09-05 18:32
共1个回答
热心网友 时间:2024-10-26 14:45
导读:本篇文章首席CTO笔记来给大家介绍有关Python1到20的阶乘和是多少的相关内容,希望对大家有所帮助,一起来看看吧。
用python求1到20阶乘的和res=0
fac=1
foriinrange(1,21):
fac*=i
res+=fac
从一的阶乘加到二十的阶乘的和是多少?
和是:2561327494111820300。
以下是通过C进行的计算:
#include"stdio.h"
voidmain()
{
inti;
doubles=0,x=1;
for(i=1;i=20;i++)
{
x=x*i;
s=s+x;
}
printf("%.0f",s);
}
运行结果:2561327494111820300。
1到20阶乘之和是多少268040729
你自己也用这人算一下。
#include"stdio.h"
longfac(intk)
{longf=1;
inti;
for(i=1;i=k;i++)
f=f*i;
returnf;
}
main()
{longy=0,i,n,m;
scanf("%ld",n);
m=n;
for(i=0;in;i++,m--)
y=y+fac(m);
printf("y=%ld",y);
getch();
}
python中如何用for语句写出从1的阶乘到20的阶乘的加和?defsum_factorial(start,stop):
?#递归求阶乘
?deffactorial(n):
??ifn==0:return1
??returnn*factorial(n-1)
?#生成器解析式生成各个数的阶乘,然后再求和
?returnsum(factorial(i)foriinrange(start,stop+1))
#调用函数,测试代码
print(sum_factorial(1,20))
注意:
在不调用库的情况下,最容易想到的就是循环里面套循环,不过这样子占用时间为O(n^2)。当然你这里也就n=20,两层循环没啥问题,不过当n足够大时,可以考虑用算法。
递归算法占用时间为O(n),一个for循环为O(stop+1-start),两者相加,比两层循环效率高,当然这也是在n足够大的时候,才谈效率。
1到20阶乘的和等于多少268040729//1的阶乘+2的阶乘+3的阶乘+......20的阶乘
voidmain()
{
staticunsignedlongintSum=0;
unsignedlongresult=0;
for(inti=1;i21;i++)
{
Sum+=f(i);
}
cout"Sumis:"Sumendl;
}
longf(intn)
{
if(n==1)
return1;
else
{
returnn*f(n-1);
}
}
结语:以上就是首席CTO笔记为大家整理的关于Python1到20的阶乘和是多少的相关内容解答汇总了,希望对您有所帮助!如果解决了您的问题欢迎分享给更多关注此问题的朋友喔~