• 二分法习题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;
    }

    */

    我要坚持一年,一年后的成功才是我想要的。
  • 相关阅读:
    nopCommerce中缓存学习
    EF
    路由
    webapi的加密方式
    生成N位数字随机数
    C# DataTable 转 实体类
    WebBrowser 打印
    文件上传控件,格式统一
    sqlserver 表循环-游标、表变量、临时表
    VB 老旧版本维护系列---迷之集合- dataTable
  • 原文地址:https://www.cnblogs.com/tianxia2s/p/3851300.html
Copyright © 2020-2023  润新知