/*
Name: 02_二分法求函数的零点
Copyright:
Author:
Date: 23-01-18 14:11
Description:
查看 提交 统计 提问
总时间限制: 1000ms 内存限制: 65536kB
描述
有函数:
f(x) = x5 - 15 * x4+ 85 * x3- 225 * x2+ 274 * x - 121
已知 f(1.5) > 0 , f(2.4) < 0 且方程 f(x) = 0 在区间 [1.5,2.4] 有且只有一个根,请用二分法求出该根。
输入
无。
输出
该方程在区间[1.5,2.4]中的根。要求四舍五入到小数点后6位。
样例输入
无
样例输出
不提供
*/
#include<iostream>
#include<cmath>
#include<cstdio>
#include<cstdlib>
using namespace std;
double f(double x);
void Fun1(); //枚举法,枚举每一个解看是否成立。
void Fun2(); //分治法,枚举区间,看解存在于哪个区间里,逐渐缩小区间范围,确定解。
int main()
{
Fun1();
Fun2();
}
void Fun1()
{
for (double x=1.5;x<=2.4;x+=0.000001)//枚举法
{
if (f(x-0.0000005)*f(x+0.0000005)<=0)
printf("%.6lf",x);
}
}
void Fun2()
{
double x1=1.5,x2=2.4,xx;
while (x2-x1>=0.000001)
{
xx = (x1+x2)/2;
if (f(xx) > 0)
x1=xx;
else
x2=xx;
}
printf("%.6lf",x1);
}
double f(double x)
{
return x*x*x*x*x-15*x*x*x*x+85*x*x*x-225*x*x+274*x-121;
}
02_二分法求函数的零点
最新推荐文章于 2022-09-06 16:51:22 发布