zoukankan      html  css  js  c++  java
  • 二分法习题HDU2199

    AC代码

    #include<iostream>
    #include<cmath>
    using namespace std;
    double y;
    double f(double n)
    {
    return 8*pow(n,4)+7*pow(n,3)+2*pow(n,2)+3*n+6;
    }
    double find()
    {
    double mid;
    double a,b;
    a=0;b=100;
    while(b-a>1e-6)
    {
    mid=(a+b)/2;
    if(f(mid)<y)
    a=mid+1e-7;
    else
    b=mid-1e-7;
    }
    return (a+b)/2.0;
    }
    int main()
    {
    int t;
    cin>>t;
    while(t--)
    {
    cin>>y;
    if(f(0)<=y&&y<=f(100))
    printf("%.4lf ",find());
    else
    cout<<"No solution! ";
    }

    return 0;}

    ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

    /*

    在这里一共使用了两个函数,一个用来保存函数的计算结果,这个是值得自己以后参考的东西,尽量自己去模仿、

    还有一个就是本题关键的二分法的算法了,下面来仔细分析分析

    double find()
    {
    double mid;
    double a,b;//关键是有三个指针起到一个指向作用
    a=0;b=100;//开始的指针初始化
    while(b-a>1e-6)//这个是程序停止运行的一个必须满足的条件
    {
    mid=(a+b)/2;
    if(f(mid)<y)
    a=mid+1e-7;
    else
    b=mid-1e-7;//取中间值,但是还是有变化的,这个也是非常主要的,没有处理好可能就会陷入一个死循环
    }
    return (a+b)/2.0;
    }

    */

    我要坚持一年,一年后的成功才是我想要的。
  • 相关阅读:
    通过JavaScript垃圾回收机制来理解WeakSet/WeakMap中对象的弱引用
    json处理
    dotenv 加载本地环境变量
    各种ast库
    类型检测库
    npm 加解密库
    用计算机语言的爱情表白
    情侣在招聘会上搂抱招致企业反感
    《软件性能测试与LoadRunner实战》网上订购问题
    F1赛车的起源
  • 原文地址:https://www.cnblogs.com/tianxia2s/p/3851300.html
Copyright © 2011-2022 走看看