1001

概述:给定一个函数y=f(x),给定y的值,在1-100的范围内,求x的值。

思路:二分搜索最最最最最最入门的题,直接二分就可以了。

感想:终于找到一个一眼就能看出答案的题了-  =。

#include<iostream>
#include<cmath>
#include<cstdio>
using namespace std;
inline double f(double x)
{
	return 8 * pow(x, 4) + 7 * pow(x, 3) + 2 * pow(x, 2) + 3 * x + 6;
}
int main()
{
	int n;
	double y;
	cin >> n;
	while (n--)
	{
		cin >> y;
		double x1 = 0, x2 = 100;
		if ((f(0)>y&&f(100)>y) || (f(0)<y&&f(100)<y))
		{
			cout << "No solution!\n";
			continue;
		}
		while (x2 - x1 >=1e-7)
		{
			if (f((x1 + x2) / 2)>y)
				x2 = (x1 + x2) / 2;
			else if (f((x1 + x2) / 2) == y)
				break;
			else
				x1 = (x1 + x2) / 2;
		}
		printf("%0.4lf\n", (x1 + x2) / 2);
	}
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值