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;
    }

    */

    我要坚持一年,一年后的成功才是我想要的。
  • 相关阅读:
    JDK15视频会及新特性总节
    设计模式之访问者模式
    datax分析与思考(一)
    beanfactory中单例bean的初始化过程(一)
    IIS 404错误,错误代码:0x80070002
    WebApi
    多线程--程序员必修课
    委托(续2)
    委托(续)
    委托
  • 原文地址:https://www.cnblogs.com/tianxia2s/p/3851300.html
Copyright © 2011-2022 走看看