noi.openjudge 二分法求函数的零点

二分法求函数的零点

总时间限制: 1000ms 内存限制: 65536kB
描述 有函数:f(x) = x5 - 15 * x4+ 85 * x3- 225 * x2+ 274 * x - 121 已知 f(1.5) > 0 , f(2.4) < 0 且方程 f(x) = 0 在区间 [1.5,2.4] 有且只有一个根,请用二分法求出该根。 输入 无。 输出 该方程在区间[1.5,2.4]中的根。要求四舍五入到小数点后6位。

解析

浮点二分练手题,首先打个表判断函数在[1.5,2.4]的单调性,直接二分出答案即可

代码
#include<bits/stdc++.h>
using namespace std;

double check(double a)
{
    double ans=pow(a,5)-15*pow(a,4)+85*pow(a,3)-225*pow(a,2)+274*a-121;//单调递减
    if(ans>0) return false;//大于目标mid往大取
    else return true;
}//a越大结果越小 

int main()
{
    double dlt=0.0000000001;
    double l=1.50,r=2.40;
    while(fabs(r-l)>dlt)//记得取fabs
    {    
        double mid=(l+r)/2.0;//除以2.0
        if(check(mid)) r=mid;//这里是r=mid 
        else l=mid;
    }
    cout<<setprecision(7)<<l<<endl;//setprecision要加一位 
    return 0;
}

 

 

转载于:https://www.cnblogs.com/KyleDeng/p/9927682.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值