鱼C论坛

 找回密码
 立即注册
查看: 1388|回复: 1

[已解决]一元三次方程解的二分边界确定

[复制链接]
发表于 2023-11-10 20:23:43 | 显示全部楼层 |阅读模式
4鱼币
  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. double a,b,c,d;
  4. double solve(double x)
  5. {
  6.     return a*x*x*x+b*x*x+c*x+d;
  7. }
  8. int main()
  9. {
  10.     cin>>a>>b>>c>>d;
  11.     for(double i=-100;i<=100;i++)  //即在-100到100中一个一个区间去判断
  12.     {
  13.         double x1=i,x2=i+1.0;
  14.         if(solve(x1)==0.0)printf("%.2lf",i); //如果带进去x1==0,则说明就是此方程的根
  15.         if(solve(x1)*solve(x2)<0)//标明此处必有一个根,然后去判断
  16.         {
  17.             while(x2-x1>=0.001)
  18.             {
  19.                 double mid=(x1+x2)/2.0;
  20.                 if(solve(x1)*solve(mid)<=0.0)x2=mid;
  21.                 else x1=mid;


  22.             }
  23.             printf("%.2lf",x1);
  24.         }

  25.     }
  26.     return 0;


  27. }
复制代码

为什么右边界不能取2.0呢,要取1.0呢,此题应该怎么确定左右边界
最佳答案
2023-11-10 20:23:44
在这段代码中,右边界不能取2.0而要取1.0的原因是因为在二分法中,我们需要保证左右边界的差值足够小,以确保找到方程的根。在这段代码中,作者选择了一个固定的精度值0.001来确定根的位置,因此右边界应该取为1.0而不是2.0。

要确定左右边界,我们可以通过观察方程的根的范围来选择合适的边界。一种方法是通过计算方程的导数来找到极值点,然后确定根的范围。另一种方法是通过观察方程图像的走势来确定根的范围。在这个特定的问题中,我们可以通过计算方程的导数来找到极值点,然后选择极值点附近的两个点作为左右边界。

综上所述,为了确定左右边界,我们可以通过计算方程的导数或观察方程图像的走势来找到根的范围,并选择合适的边界值来进行二分法求解。

最佳答案

查看完整内容

在这段代码中,右边界不能取2.0而要取1.0的原因是因为在二分法中,我们需要保证左右边界的差值足够小,以确保找到方程的根。在这段代码中,作者选择了一个固定的精度值0.001来确定根的位置,因此右边界应该取为1.0而不是2.0。 要确定左右边界,我们可以通过观察方程的根的范围来选择合适的边界。一种方法是通过计算方程的导数来找到极值点,然后确定根的范围。另一种方法是通过观察方程图像的走势来确定根的范围。在这个特定的 ...
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-11-10 20:23:44 | 显示全部楼层    本楼为最佳答案   
在这段代码中,右边界不能取2.0而要取1.0的原因是因为在二分法中,我们需要保证左右边界的差值足够小,以确保找到方程的根。在这段代码中,作者选择了一个固定的精度值0.001来确定根的位置,因此右边界应该取为1.0而不是2.0。

要确定左右边界,我们可以通过观察方程的根的范围来选择合适的边界。一种方法是通过计算方程的导数来找到极值点,然后确定根的范围。另一种方法是通过观察方程图像的走势来确定根的范围。在这个特定的问题中,我们可以通过计算方程的导数来找到极值点,然后选择极值点附近的两个点作为左右边界。

综上所述,为了确定左右边界,我们可以通过计算方程的导数或观察方程图像的走势来找到根的范围,并选择合适的边界值来进行二分法求解。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-21 14:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表