首页 > 编程语言 > 详细

算法训练——一元三次方程求解

时间:2020-01-29 14:30:51      阅读:95      评论:0      收藏:0      [点我收藏+]

 

//一元三次方程求解
//直接枚举 
#include<stdio.h>
#include<math.h>
double a,b,c,d,x;
double f(double x){
	return a*x*x*x + b*x*x + c*x + d; 
} 
int main(){
	scanf("%lf%lf%lf%lf",&a,&b,&c,&d);
	for(x=-100;x<=100;++x){
		double z = x,y = z+1;
		if(f(z) == 0){
			printf("%.2f ",z);
		}
		else{
			if((f(z) * f(y)) < 0){	//x位于z与y之间	分治 
				while(y-z >= 0.001){
					double mid = (z+y)/2;
					if((f(z) * f(mid)) <= 0){
						y = mid;
					}
					else{
						z = mid;
					}
				}
				printf("%.2f ",z);
			} 
		} 
	}
	printf("\n");	 
	return 0;
} 
 

  

算法训练——一元三次方程求解

原文:https://www.cnblogs.com/Hqx-curiosity/p/12240160.html

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