社区讨论

dalao求掉

P1024[NOIP 2001 提高组] 一元三次方程求解参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@lokvfw5y
此快照首次捕获于
2023/11/05 10:45
2 年前
此快照最后确认于
2023/11/05 12:13
2 年前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
int a,b,c,d;
double f(int x)
{
	return (a*x*x*x+b*x*x+c*x+d);
}
double sswr(double a)
{
	return ((int)a*1000)%10>=5?((int)(a*100+1))/100.0:((int)(a*100))/100.0;
}
int main()
{
	double x1,x2,x,s;
	scanf("%d %d %d %d",&a,&b,&c,&d);
	for(int i=-100;i<=100;i++)
	{
		x1=i;
		x2=i+1;
		if(f(x1)*f(x2)<0)
		{
			x=(x1+x2)/2;
			s=sswr(f(x));
			while(s!=0)
			{
				s=sswr(f(x));
				if(s<0)
				{
					x2=x;
					x=(x1+x2)/2;
				}
				else if(s>0)
				{
					x1=x;
					x=(x1+x2)/2;
				}
			}
			printf("%.2f ",x);
		}
		else if(f(x1)==0)
		     printf("%.2f ",x1);
	}
	return 0;
}
第二个和第四个点

回复

0 条回复,欢迎继续交流。

正在加载回复...