还是用迭代法求解一个方程题,f(x)=0,如果f(x1)<0,f(x2)>0,如果f(x)是连续的,则在x1和x2
之间一定有一个值x~,使得f(x~)=0。首先用步骤描述解题框架:
1、任意找两个点x1、x2,使得f(x1)<0,f(x2)>0
2、计算x1、x2的中间点的值mid=(x1+x2)/2
3、计算f(mid),如果f(mid)>0,则最终的结果值在 x1,mid之间,将x2赋值为mid,继续1、2、3、4步骤;
如果f(mid)<0,则最终的结果值在mid,x2之间,将x1赋值为mid,继续1,2,3,4步骤
4、计算|x1-x2|是否小于某个精确度值,如果小于的话直接返回mid值,表示在该精确度范围内已经找到了
近似的解了。
如下图 f(x)=x^2-5的方程图,按照上述步骤计算f(x)=0的解
首先f(0)<0,f(4)>0,就选定0、4为初始的x1,x2来计算解,精确度定位1e-9,代码如下:
public static void main(String[] args){
System.out.println(calculate(0,4,1e-9));
}
public static double calculate(double x1,double x2,double precision){
double mid=(x1+x2)/2;
while(Math.abs(x1-x2)>precision){
if(calculate(x2)*calculate(mid)>0){
x2=mid;
}else{
x1=mid;
}
mid=(x1+x2)/2;
}
return mid;
}
public static double calculate(double x){
return 2*x*x-5;
}
输出结果:1.58113883016631
总结:迭代就是先确定一个值为初始值,然后以这个初始值为新的变量带入计算规则,将计算出的再作为新
的变量带入计算规则(函数,也就是方程),最后满足条件的话直接返回结果。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
2017-08-30 Java运行时数据区