zoukankan      html  css  js  c++  java
  • pat03-树1. 二分法求多项式单根(20)

    03-树1. 二分法求多项式单根(20)

    时间限制
    400 ms
    内存限制
    65536 kB
    代码长度限制
    8000 B
    判题程序
    Standard
    作者
    杨起帆(浙江大学城市学院)

    二分法求函数根的原理为:如果连续函数f(x)在区间[a, b]的两个端点取值异号,即f(a)f(b)<0,则它在这个区间内至少存在1个根r,即f(r)=0。

    二分法的步骤为:

    • 检查区间长度,如果小于给定阈值,则停止,输出区间中点(a+b)/2;否则
    • 如果f(a)f(b)<0,则计算中点的值f((a+b)/2);
    • 如果f((a+b)/2)正好为0,则(a+b)/2就是要求的根;否则
    • 如果f((a+b)/2)与f(a)同号,则说明根在区间[(a+b)/2, b],令a=(a+b)/2,重复循环;
    • 如果f((a+b)/2)与f(b)同号,则说明根在区间[a, (a+b)/2],令b=(a+b)/2,重复循环;

      本题目要求编写程序,计算给定3阶多项式f(x)=a3x3+a2x2+a1x+a0在给定区间[a, b]内的根。

      输入格式:

      输入在第1行中顺序给出多项式的4个系数a3、a2、a1、a0,在第2行中顺序给出区间端点a和b。题目保证多项式在给定区间内存在唯一单根。

      输出格式:

      在一行中输出该多项式在该区间内的根,精确到小数点后2位。

      输入样例:
      3 -1 -3 1
      -0.5 0.5
      
      输出样例:
      0.33
      

    提交代码

     1 #include<cstdio>
     2 #include<algorithm>
     3 #include<iostream>
     4 #include<cstring>
     5 #include<queue>
     6 #include<vector>
     7 #include<cmath>
     8 #include<string>
     9 using namespace std;
    10 #define exp 1e-8
    11 double con[4],a,b,mid;
    12 double f(double a){
    13     double sum=0;
    14     int i;
    15     for(i=0;i<4;i++){
    16         sum*=a;
    17         sum+=con[i];
    18     }
    19     return sum;
    20 }
    21 int main(){
    22     //freopen("D:\INPUT.txt","r",stdin);
    23     int i;
    24     for(i=0;i<4;i++){
    25         scanf("%lf",&con[i]);
    26     }
    27     scanf("%lf %lf",&a,&b);
    28     while(b-a>exp){
    29         mid=f((a+b)/2);
    30 
    31         //cout<<mid<<endl;
    32 
    33         if(fabs(mid)<exp){
    34             break;
    35         }
    36         if(f(a)*mid>exp){
    37             a=(a+b)/2;
    38         }
    39         else{
    40             b=(a+b)/2;
    41         }
    42     }
    43     printf("%.2lf
    ",(a+b)/2);
    44     return 0;
    45 }
  • 相关阅读:
    SpringMVC数据绑定
    SpringMVC概述
    应用Spring和Hibernate(C3P0数据池)写数据库交互项目
    Spring的AOP特性
    Sping框架的IOC特性
    MD5加密字符串
    重力感应 视频横竖屏切换
    自定义View(三)实现简单的可拖动、可缩放的ImageView
    自定义View(二)增加View的属性
    自定义View的学习(一) 自绘制控件
  • 原文地址:https://www.cnblogs.com/Deribs4/p/4749469.html
Copyright © 2011-2022 走看看