洛谷P1024[NOIP 2001 提高组]一元三次方程求解

数据不大

死算就行

要注意一点

有时候x可能是循环小数

就会导致找不到数据

那就可以判断得出答案零是否在一个区间

是的话就去中间数

这样更精确

可以避免结果不是三个的情况

以下是代码

//初始化
#include <bits/stdc++.h>

//命名文件
using namespace std;

//定义变量
double a,b,c,d,s1,s2;

//定义算方程右边数字
double f(double x){
	//返回数字
	return a * x * x * x + b * x * x + c * x + d;
}

//定义主函数
int main(){
	//输入
	cin>>a>>b>>c>>d;
	
	//纯模拟,死算,反正不大
	for(double i = -100;i <= 100;i = i + 0.0001){
		//算两边,防止x是循环的,反正前两位,在区间内就行了
		s1 = f(i);
		s2 = f(i + 0.0001);
		
		//判断
		if(s1 <= 0 && s2 >= 0 || s2 <= 0 && s1 >= 0){
			printf("%.2lf ",(i + i + 0.0001) / 2);
		}
	}
	
	//返回
	return 0;
}

点个赞吧!!!求求了!!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值