算法学习——枚举之超级方程
本文为作者原创,允许转载,不过请在文章开头明显处注明链接和出处!!! 谢谢配合~
作者:stars-one
链接:https://www.cnblogs.com/stars-one/p/9652958.html
本篇大约有1302个字,阅读预计需要1.63分钟
算法描述
求区间(2,3)的一个解,精确到小数点后8位
算法思路
-
首先是要判断该区间是否有解,这里使用数学中的定义,
f(a)\*f(b)<0
,则在a与b之间有解,我们从2开始,逐渐加0.1,与f(3)相乘,判断两者之积是否为0,即可知道是否有解 -
有解的话我们就可以继续下一步了,先设置一个数值min,从f(2)开始,一次加上0.1,寻找f(x)最小数值时候的x的值,以此x的值缩小范围,继续重复之前的步骤,经过多次循环之后,即可找到精度较大的x
算法实现
double a,b;
System.out.println("输入上限");
Scanner scanner = new Scanner(System.in);
a = scanner.nextInt();
System.out.println("输入下限");
b = scanner.nextInt();
scanner.close();
boolean isHave = false;//false无解
for(double i = a;i<=b;i=i+0.1){
if(fun(i)*fun(b)<=0){
isHave = true;
break;
}
}
if(isHave){
System.out.println("有解");
int k = 1;
double y,c = 0.1,min=100,x1=0;//min赋值一个较大的初值
while(k<=8){
for(double x=a;x<=b;x=x+c){
//System.out.println(x);
y = fun(x);
if(Math.abs(y)<min){
min = Math.abs(y);
x1 = x;
}
}
c = c/10;
//System.out.println(c);
a = x1-5*c;
b = x1+5*c;
k++;
}
DecimalFormat fm = new DecimalFormat("0.00000000");
System.out.println(fm.format(x1));
}else{
System.out.println("无解");
}
public static double fun(double x){
return 2*Math.pow(x, 2)*Math.pow(Math.sin(x), 7)+3*Math.pow(x, 0.5)*Math.cos(x)-Math.exp(x)/5;
}
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】博客园携手 AI 驱动开发工具商 Chat2DB 推出联合终身会员
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· golang自带的死锁检测并非银弹
· 如何做好软件架构师
· 记录一次线上服务OOM排查
· Linux实时系统Xenomai宕机问题的深度定位过程
· 记一次 .NET某汗液测试机系统 崩溃分析
· 2025年广告第一单,试试这款永久免费的开源BI工具
· o3 发布了,摔碎了码农的饭碗
· SQL优化的这15招,真香!
· [.NET] API网关选择:YARP还是Ocelot?
· 将 EasySQLite 从 .NET 8 升级到 .NET 9