hdu2199(方程求值二分法)

题意:方程 8* X ^ 4 + 7 * X ^ 3 + 2 * X ^ 2 + 3 * X + 6 == Y,x取值在0和100之间,现在给你一个Y 让你求x的值

思路:二分,因为方程为单调递增序列,所以先将50( mid = (0+100) / 2 )带入方程得到Y1值,比较Y和Y1的大小,

如果Y1 < Y 说明x的取值小了 ,然后解得区间 就变成left = mid [mid , right]

如果Y1 > Y 说明x的取值大了,然后解得区间就变成 right = mid [left , mid]

继续查找至循环结束,mid就是解

#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;
const double eps = 1e-8;//精度
double f(double x)
{
	return 8*pow(x,4)+7*pow(x,3)+2*pow(x,2)+3*x;
}
int main()
{
	int t;
	scanf("%d",&t);
	while(t--)
	{
		int Y,flag = 0;
		scanf("%d",&Y);
		double left = 0,right = 100.0,mid;
		if(Y - 6 < 0)
		{
			printf("No solution!\n");continue;
		}
		if(f(0) <= Y && Y <= f(100))
		{
			while((right - left) > eps)// (left - right) < eps 这样和下面会出现矛盾,当left 等于right 时0 < eps 会进入死循环,所以反过来写
			{
				mid = (left + right) / 2.0;
				double sum = f(mid);
				if(sum > Y-6)
				{
					right = mid;
				}
				else if(sum < Y-6)
				{
					left = mid;
				}
			}	
			printf("%.4lf\n",mid);continue;
		}
		printf("No solution!\n");
	}
	return 0;
}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值