STL6----K - Light Bulb

本文探讨了在ZOJ3203问题中,如何利用高精度计算解决复杂数学问题。通过采用特定制导搜索算法,如三等分法,实现了对函数solve(x)的精确求解。该文详细介绍了算法的实现过程,包括初始化参数、设置搜索区间及迭代求解,最终输出了求解结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

zoj3203

这道题对精度的要求很高。

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cmath>
using namespace std;
const double MAX = 1e4;
const double ESP = 1e-10;
double H, h, D;
double solve(double x)
{
 return D - x + H - (H - h)*D / x;
 //h * (D + x) / H - x + x * H / (D + x);//(h * (D + x) * (D + x) + H * H * x - D * H * x - x * x * H) / (H*(D + x));
 //return h * (D + x) / H - x + x * h / ();//(h * (D + x) * (D + x) + H * H * x - D * H * x - x * x * H) / (H*(D + x));
}
int main()
{
 int t; cin >> t;
 while (t--)
 {
  cin >> H >> h >> D;
  double lt = (H - h)*D / H, rt = D, mid, midmid;
  //cout << "ckjjv" << endl;
  while (rt - lt >= ESP)
  {
   //cout << lt << " " << rt << endl;
   mid = lt + (rt - lt) / 3;
   midmid = rt - (rt - lt) / 3;
   if (solve(mid) >= solve(midmid)) rt = midmid;
   else lt = mid;
  }
  printf("%.3lf\n", solve(lt));
 }
 return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值