首页 > 其他 > 详细

P1024 一元三次方程求解

时间:2020-10-11 18:51:06      阅读:41      评论:0      收藏:0      [点我收藏+]

实数二分的题。
第一次写的时候,发现这样的写法无法处理mid正好是根的情况,会重复输出mid。
巧就巧在这题的数据保证不会出现长度为1的区间内出现2个根的情况,所以可以改写代码。

原始代码

#include<iostream>
#include<cstdio>

using namespace std;

double a, b, c, d;

double calc(double x){
    return a * x * x * x + b * x * x + c * x + d;
}

void dfs(double l, double r){
    if(r - l <= 1e-3){
        if(calc(l) * calc(r) <= 0) printf("%.2lf ", l);
        return;
    }
    double mid = (l + r) / 2;
    dfs(l, mid), dfs(mid, r);
}

int main(){
    cin >> a >> b >> c >> d;
    
    dfs(-100, 100);
}

改写代码

因为题目数据保证不会出现长度为1的区间内出现2个根的情况,所以如果mid为根,那么[mid - 1, mid) 区间内一定不会有根,所以就可以扔掉这个区间了,保证不会重复输出mid。

#include<iostream>
#include<cstdio>

using namespace std;

double a, b, c, d;

double calc(double x){
    return a * x * x * x + b * x * x + c * x + d;
}

void dfs(double l, double r){
    if(r - l <= 1e-3){
        if(calc(l) * calc(r) <= 0) printf("%.2lf ", l);
        return;
    }
    double mid = (l + r) / 2, d = 0;
    if(calc(mid) == 0) d = 1;
    dfs(l, mid - d), dfs(mid, r); 
}

int main(){
    cin >> a >> b >> c >> d;
    
    dfs(-100, 100);
}

P1024 一元三次方程求解

原文:https://www.cnblogs.com/tomori/p/13797880.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!