瞎折腾


私信TA

用户名:chenbin

访问量:61054

签 名:

等  级
排  名 72
经  验 9734
参赛次数 0
文章发表 74
年  龄 0
在职情况 学生
学  校 中南大学
专  业

  自我简介:

解题思路:
二分法求解近似值




注意事项:





参考代码:

#include<stdio.h>    

double cf[30];   

int main()  

{  

    int i,j,n;  

    double s,f,x,l,r,m;  

    while(scanf("%d",&n)!=EOF)  

    {  

        if(n==0)    //当输入值为0时退出循环运算

            break;  

        scanf("%lf",&x);  

        for(i=0;i<n;i++)  

            scanf("%lf",&cf[i]);  

        l=-1.0;          //设置左区间

        r=1e6;          //设置右区间

        for(i=0;i<100;i++)  

        {  

            s=0;  

            f=1.0;  

            m=(l+r)/2;   //取中间值

            for(j=0;j<n;j++)  

            {  

                f=f/(1+m);  

                s=s+cf[j]*f;  

            }  

            if(s>(-x))  

                l=m;        //近似值可能落入右区间 

            else  

                r=m;        //近似值可能落入左区间

        }  

        printf("%.2lf\n",m);  

    }  

    return 0;  

}  











 

0.0分

0 人评分

  评论区

你设置左右区间有什么用
2019-09-24 19:17:04
if(s>(-x))  
                l=m;        //近似值可能落入右区间 
            else  
                r=m;        //近似值可能落入左区间             有什么用
2019-09-23 19:39:51
  • «
  • 1
  • »