[NOIP2001 提高组] 一元三次方程求解

#

## 题目描述

有形如:$a x^3 + b x^2 + c x + d = 0$  这样的一个一元三次方程。给出该方程中各项的系数($a,b,c,d$ 均为实数),并约定该方程存在三个不同实根(根的范围在 $-100$ 至 $100$ 之间),且根与根之差的绝对值 $\ge 1$。要求由小到大依次在同一行输出这三个实根(根与根之间留有空格),并精确到小数点后 $2$ 位。

提示:记方程 $f(x) = 0$,若存在 $2$ 个数 $x_1$ 和 $x_2$,且 $x_1 < x_2$,$f(x_1) \times f(x_2) < 0$,则在 $(x_1, x_2)$ 之间一定有一个根。

## 输入格式

一行,$4$ 个实数 $a, b, c, d$。

## 输出格式

一行,$3$ 个实根,从小到大输出,并精确到小数点后 $2$ 位。

## 样例 #1

### 样例输入 #1

```
1 -5 -4 20
```

### 样例输出 #1

```
-2.00 2.00 5.00
```

## 提示

**【题目来源】**

NOIP 2001 提高组第一题

#include<cstdio>
#include<iostream>
using namespace std;
double a,b,c,d;
double fc(double x)//记录乘积结果 
{
    return a*x*x*x+b*x*x+c*x+d;
}
int main()
{
	double l,r,m,x1,x2;
	int s=0;
	cin>>a>>b>>c>>d;//输入a,b,c,d; 
	for(int i=-100;i<=100;i++)//从-100到100进行循环 
	{
		l=i;
		r=i+1;
		x1=fc(l);
		x2=fc(r);//如果这个两个相差1的相乘小于0 则说明零点在这中间。 
		if(!x1) 
		{
		    printf("%.2lf ",l); 
		    s++;//如果是整数算进,直接等于0则直接输出 
	    }  
		if(x1*x2<0)
		{
			while(r-l>=0.001)//精度0.001 
			{
					m=(l+r)/2;//二分法 
					if(fc(m)*fc(r)<=0)
					{
						l=m;
					}	
					else
						r=m;
			}
			printf("%.2lf ",r);
		 	s++;
		}
	if(s==3)//三个截止 
	break;
		
	} 
	return 0;
} 
  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值