HDU - 2199:Can you solve this equation?(二分求根、零点逼近)

题目链接:Can you solve this equation?

题目大意:多项式求根,精确到10-4,数据范围是0到100

思路:很明显该多项式在0到100是递增的,故可以用零点逼近法,先求出多项式的最大值和最小值,然后在这个区间二分搜索,直到满足精度为止

AC代码:

#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;

double f(double x,int y)
{
    return 8*pow(x,4)+7*pow(x,3)+2*pow(x,2)+3*x+6-y;
}

int main()
{
    int t,y;
    cin>>t;
    while(t--)
    {
        cin>>y;
        double low=0;
        double high=100;
        if(f(low,y)>0 || f(high,y)<0)
            printf("No solution!\n");
        else{
            double mid;
            while(high-low>=1e-6){//由于要精确到小数点后四位,所以第五位的值也应该是准确的,
                mid=low+(high-low)/2;//故要估算到小数点后六位
                if(f(mid,y)>0) high=mid;
                else if(f(mid,y)<0) low=mid;
                else break;
            }
            printf("%0.4f\n",mid);
        }
    }
    return 0;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值