AcWing 790. 数的三次方根

题目描述


分析:

本题为二分的应用。区间可设为 − 10000 ≤ n ≤ 10000 −10000≤n≤10000 10000n10000,这也说明了二分的本质不是单调,而是边界。
首先根据 l l l r r r 的中点 m i d mid mid 处的三次方和 n n n 的大小来选择子区间进行逼近。
这里假设输入为 8 8 8,用图模拟下局部二分过程。

  1. 如果 m i d ∗ m i d ∗ m i d ≥ n mid * mid * mid ≥ n midmidmidn,则说明 m i d ≥ n mid ≥ n midn 的三次方根,则应当在 [ l , m i d ] [l,mid] [l,mid] 的范围内继续逼近,故令 r = m i d r = mid r=mid;
    Screenshot_20220708_211958_com.jideos.jnotes.jpg
  2. 如果 m i d ∗ m i d ∗ m i d < n mid * mid * mid < n midmidmid<n,则说明 m i d < n mid < n mid<n 的三次方根,则应当在 [ m i d , r ] [mid,r] [mid,r] 的范围内继续逼近,故令 l = m i d l = mid l=mid;
    Screenshot_20220708_212106_com.jideos.jnotes.jpg

上面两部直至 $r - l < 10^{-8} $时结束(这里有一个问题就是如果结果保留 k k k 位小数,这里就是 1 0 − ( k + 2 ) 10^{-(k+2)} 10(k+2))。
C++ 代码中保留 n n n 位小数需要加入头文件iomanip,以及 cout << setprecision(n) << std::fixed << ...


代码(C++)

#include <iostream>
#include <iomanip>

using namespace std;

int main()
{
    double n;
    cin >> n;
    
    double l = -10000, r = 10000;
    
    while (r - l > 1e-8)
    {
        double mid = (l + r) / 2;
        if (mid * mid * mid >= n) r = mid;
        else l = mid;
    }
    
    cout << setprecision(6) << std::fixed << l << endl;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值