易水卷长空 2021-11-10 12:49 采纳率: 100%
浏览 36
已结题

C语言-递归与循环的计算结果不一样

同样的公式,算法不同,结果有细微差别

img

#include <stdio.h>
double p(double x,int n){
    if(n==0){
        return 1;
    }else if(n==1){
        return x;
    }else{
        return ((2*n-1)/(double)n)*x*p(x,n-1)-((n-1)/(double)n)*p(x,n-2);
    }
}
double pp(double x,int n){
    double pn=0,p1=1,p2=x;
    int i=0;
    if(n==0)
        pn=1;
    else if(n==1)
        pn=x;
    else if(n>1){
          for(i=2;i<=n;i++){
              pn=((2*i-1)/(double)i)*x*p2-((i-1)/(double)i)*p1;
              p1=p2;
              p2=pn;
          }
    }
    return pn;
}
int main()
{
    double x=0;
    int n=0;
    scanf("%lf%d",&x,&n);
    printf("递归%.2f\n",p(x,n));
    printf("循环%.2f",pp(x,n));
    return 0;
}

img


img

  • 写回答

1条回答 默认 最新

  • 从善若水 优质创作者: 信息安全技术领域 2021-11-10 13:05
    关注

    这个是浮点数的精度误差,没问题

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月18日
  • 已采纳回答 11月10日
  • 创建了问题 11月10日