站点图标 陌路寒暄

改错题B-阶乘和

改错题B-阶乘和

时间: 1ms        内存:128M

描述:

注意:只提交程序中需要修改的部分

求表达式1! + 3!+ .... +(2n-1)!的值

C程序

#include <stdio.h>
long int fact(int n)
{
    long int f=1;
 int i;
    for(i=2; i<=n; i++)
        f=f*i;
    return f;
}

int main()
{
    long int sum ;
    int i,n;
    scanf("%d",&n);
    /*****修改的起始行******/
    for(sum=i=1; i<=n; i++)   //可能出错行
    {
        sum=sum + fact(i);      //可能出错行
    }
    /*****修改的终止行*****/
    printf("%d\n",sum);
    return 0;
}

C++程序

#include <iostream>
using namespace std;
long int fact(int n)
{
long int f=1;
for(int i=2; i<=n; i++)
f=f*i;
return f;
}

int main()
{
long int sum ;
int i,n;
cin>>n;
/*****修改的起始行******/
for(sum=i=1; i<=n; i++) //可能出错行
{
sum=sum + fact(i); //可能出错行
}
/*****修改的终止行*****/
cout<<sum<<endl;
return 0;
}

输入:

输入n

输出:

表达式的值

示例输入:

3

示例输出:

127

提示:

参考答案(内存最优[1092]):


#include <stdio.h>
long int fact(int n)
{
    long int f=1;
	int i;
    for(i=2; i<=n; i++)
        f=f*i;
    return f;
}

int main()
{
    long int sum ;
    int i,n;
    scanf("%d",&n);    sum=0;
    for(i=1; i<=2*n-1; i+=2)   //可能出错行
    {
        sum=sum + fact(i);      //可能出错行
    }
printf("%d\n",sum);
    return 0;
}

参考答案(时间最优[0]):


#include <iostream>
using namespace std;
long int fact(int n)
{
    long int f=1;
    for(int i=2; i<=n; i++)
        f=f*i;
    return f;
}

int main()
{
    long int sum ;
    int i,n;
    cin>>n;
    for(sum=0,i=1; i<=n; i++)
    {
        sum=sum + fact(2*i-1);
    }
    cout<<sum<<endl;
    return 0;
}

题目和答案均来自于互联网,仅供参考,如有问题请联系管理员修改或删除。

退出移动版