• poj1905——二分法求单调函数零点解方程


    poj1905——二分法求单调函数零点解方程

    Expanding Rods
    Time Limit: 1000MS   Memory Limit: 30000K
    Total Submissions: 12773   Accepted: 3291

    Description

    When a thin rod of length L is heated n degrees, it expands to a new length L'=(1+n*C)*L, where C is the coefficient of heat expansion. 
    When a thin rod is mounted on two solid walls and then heated, it expands and takes the shape of a circular segment, the original rod being the chord of the segment. 

    Your task is to compute the distance by which the center of the rod is displaced. 

    Input

    The input contains multiple lines. Each line of input contains three non-negative numbers: the initial lenth of the rod in millimeters, the temperature change in degrees and the coefficient of heat expansion of the material. Input data guarantee that no rod expands by more than one half of its original length. The last line of input contains three negative numbers and it should not be processed.

    Output

    For each line of input, output one line with the displacement of the center of the rod in millimeters with 3 digits of precision. 

    Sample Input

    1000 100 0.0001
    15000 10 0.00006
    10 0 0.001
    -1 -1 -1
    

    Sample Output

    61.329
    225.020
    0.000
    题意:长度为L的铁片如图所示,升高温度C后会有一定程度的形变,长度变为NewL,呈圆弧状,求铁片中点偏离的高度
    思路:数学题,解方程时构造函数二次求导求变化趋势,二分确定零点范围,怀念高考前刷数学试卷做导数题的时光。此题需注意精度以及数据为0的特判。
    /**
     * Start at 12:53
     * End at 13:08
     * Problem: poj1905
     * Author: __560
     */
     #include<iostream>
     #include<cstdio>
     #include<cstring>
     #include<cstdlib>
     #include<algorithm>
     #include<math.h>
    
     using namespace std;
    
     const int maxn=1000100;
     const int INF=(1<<28);
     const double Pi=3.1415927;
     const double Exp=0.000000000001;
    
     double L,T,C;
     double NewL;
    
     double f(double x)
     {
         return L*x-NewL*sin(x);
     }
    
     double BinSearch(double left,double right)
     {
         while(fabs(left-right)>Exp){
            double mid=(left+right)/2;
            if(f(mid)<0) left=mid;
            else if(mid>0) right=mid;
         }
         return left;
     }
    
     int main()
     {
         while(scanf("%lf%lf%lf",&L,&T,&C)!=EOF){
            if(L==-1&&T==-1&&C==-1) return 0;
            if(L==0||T==0||C==0) puts("0.000");
            else{
                NewL=(1+C*T)*L;
                double x=BinSearch(Exp,Pi);
                double R=NewL/(2*x);
                double d=sqrt(R*R-L*L/4);
                printf("%.3f
    ",R-d);
            }
         }
     }
    View Code


    没有AC不了的题,只有不努力的ACMER!
  • 相关阅读:
    cf Round #766(Div. 2)
    网易评论盖楼效果前台实现。。。
    Golang 基础之基础语法梳理 (三)
    Golang 基础之基础语法梳理 (一)
    Golang 基础之基础语法梳理 (二)
    adonisJS mysql
    angular form表单
    adonisJS 入门(路由/控制器/模型/视图)
    angular 父子组件传值及通讯
    adonisJS 视图/查询/列表/单条
  • 原文地址:https://www.cnblogs.com/--560/p/4380596.html
Copyright © 2020-2023  润新知