用C语言 求1!+3!+5!+7!+...+n!

main()
{
int n,i,j;
long temp=1,sn=0;
scanf("%d",&n);
for(j=1;j<i;j++)
for(i=1;i<=n;i+=2)
temp*=j;
sn+=temp;
printf("%ld\n",sn);
}
小弟的基本思路就是这个语句描述的,但是这个语句显然有问题,运行结果不对。求解,最好能在我的语句上修改
彪彪和蜜桃两位的代码,运行结果都不对,tangxiucai的C++我还没深入到那一步,谢谢你了。

你的算法即使正确 效率也不高啊。事实上只要求最后一个n!就可以,只要一次循环。你的问题在temp的值在内面一重循环完成后应当重新赋为1,不然就会逐渐变很大。 代码如下:
#include<stdio.h>

int main()
{
int temp=1; //存之前已经计算的i!
int i=0,n=0, sn = 1;
scanf("%d",&n);
for(i = 3; i <= n; i = i+2) /*从3开始算起,*/
{
temp = temp*(i-1)*i;
sn += temp;
}
printf("%d\n",sn);
return 0;
}
温馨提示:答案为网友推荐,仅供参考
第1个回答  2008-04-03
我没重复啊!!
#include<stdio.h>
main()
{
int n,i,j;
long temp=1,sn=0;
scanf("%d",&n);
for(i=1;i<=n;i+=2)
{
for(temp=1,j=1;j<=i;j++)
temp*=j;
sn+=temp;
}
printf("%ld\n",sn);
}
第2个回答  2008-04-03
#include<iostream>
using namespace std;
int main()
{
int n;
int s=0.t=1;
cin>>n;
cout<<endl;
for(int i=1;i<n;i=i+2){
t=i*t;
s=s+t;
}
cout<<s<<endl;
}

这是C++
第3个回答  2008-04-03
#include"stdio.h"
main()
{
int n,i,j;
long temp,sn=0;
scanf("%d",&n);
for(temp=1,i=1;i<=n;i+=2)
for(j=1;j<=i;j++)
{temp*=j;
sn+=temp;
}
printf("%ld\n",sn);
}
相似回答