注册 登录
编程论坛 C++教室

简单的取小数点后位数的问题

abc的风格 发布于 2011-04-14 23:13, 3902 次点击
我的代码是
#include<iostream>
#include<iomanip>
using namespace std;
long fun(int n)
{
    if(n==1)    return n;
    if(n>1)
        return n*fun(n-1);
}
int main()
{
    double sum=1;int i;
    cout<<"n"<<" "<<"e"<<endl;
    cout<<"- -----------"<<endl;
    for(i=0;i<=9;i++)
    {
        sum=sum+1.0/fun(i);
        cout<<i<<" "<<setprecision(8)<<sum<<endl;    //这儿的问题
    }
    return 0;
}

问题要求的输出结果为:

n e
- -----------
0 1
1 2
2 2.5
3 2.666666667
4 2.708333333

我的结果是:

0 1
1 2
2 2.5
3 2.6666667
4 2.7083333
5 回复
#2
qq10235692232011-04-14 23:58
程序代码:
#include<iostream>
#include<iomanip>
using namespace std;
long fun(int n)
{
    if(n==1)    return n;
    if(n>1)
        return n*fun(n-1);
}
int main()
{
    double sum=1;int i;
    cout<<"n"<<" "<<"e"<<endl;
    cout<<"- -----------"<<endl;
    for(i=0;i<=9;i++)
    {
        sum=sum+1.0/fun(i);
        cout<<i<<" "<<fixed<<setprecision(9)<<sum<<endl;    //这儿的问题
    }
    return 0;
}

#3
pangding2011-04-15 07:51
setprecision 设置的是有效数位,连小数点前的也算。要加一个 fixed 才行,表示定点。正如楼上的那样。
#4
abc的风格2011-04-15 20:06
回复 2楼 qq1023569223
不对,2楼代码的结果是这样的
n e
- -----------
0 0.999999999
1 1.999999999
2 2.499999999
3 2.666666666
4 2.708333332
5 2.716666666
6 2.718055554
7 2.718253967
8 2.718278769
9 2.718281524
Press any key to continue

我要的结果是:
n e
- -----------
0 1
1 2
2 2.5
3 2.666666667
4 2.708333333
5 2.716666667
6 2.718055556
7 2.718253968
8 2.718278770
9 2.718281526
Press any key to continue

不过我发现一种可行(较笨的)但觉得不是最好的方法,希望各位继续提供更好的方法
代码如下:

#include<stdio.h>
void main()
{
    int n;
    double e,temp;
    int fac=1;
    printf("n e\n");
    printf("- -----------\n");
    printf("0 1\n");
    e=1.0;
    for(n=1;n<=2;n++)
    {
        fac=fac*n;
        temp=(double)1/fac;
        e+=temp;
        printf("%d %.3g\n",n,e);
    }
    for(n=3;n<=9;n++)
    {
        fac=fac*n;
        temp=(double)1/fac;
        e+=temp;
        printf("%d %.9f\n",n,e);
    }
}   
#5
pangding2011-04-15 22:16
楼主知道为什么結果会是这样吗?
#6
abc的风格2011-04-16 19:08
回复 5楼 pangding
应该是与sum定义的double类型有关吧
1