牛顿迭代法-朋友Z与方程

题目链接:http://115.231.222.240:8081/JudgeOnline/problem.php?id=1470;


1470: 朋友Z与方程

Time Limit: 1 Sec   Memory Limit: 128 MB
Submit: 1131   Solved: 246
[ Submit][ Status][ Web Board]

Description

朋友Z的信中她问了L先生一道题目,可惜L先生太笨,你能帮助他解决吗?

已知等式:6*x^3 + 5*x^2 + 7*x + 9 == Y 给出Y的值请求出x( 0≤x≤10)

Input

输入有多组测试数据,处理到文件结束(测试数据数量<=100000),每组测试数据给出一个浮点数Y(fabs(Y)<10 5 )。

Output

每行输出一个答案。

对于每个测试例如果存在满足条件的x,那么就输出x的值,并精确到小数点后4位,否则输出No solution! 。

Sample Input

100
-10

Sample Output

2.0877
No solution!

HINT

eps<=10-8


思路:牛顿迭代法;

代码:

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define eps 0.000001

double f(double x)
{
    return 6*x*x*x+5*x*x+7*x+9;
}

int main()
{
    double y;
    while(~scanf("%lf",&y))
    {
        double l=0,r=10;
        if(f(0)>y+eps||f(10)<y-eps)
            puts("No solution!");
        else
        {
            for(int i=0; i<50; i++)
            {
                double mid=(l+r)/2;
                if(f(mid)>y)
                    r=mid;
                else
                    l=mid;
            }

            printf("%.4f\n",l);
        }
    }
    return 0;
}

关于牛顿迭代法:

参考:http://www.matongxue.com/madocs/205.html#/madoc;

上面的参考说的很详细;


以下是我根据参考的理解...

给一个函数然后求函数的零点;

在函数上随便选取一个点(xn,f(xn)),则这一点上的切线方程为y=f'(xn) (x-xn) + f(n);那么切线与x轴的交点就是x(n+1)=xn-f(xn)/f'(xn) ;

在根据(xn+1,f(xn+1))这个点找下一个近似根,那么到什么时候为止呢,就是前一个近似根与这个近似根的差接近为0时!

代码可以根据方程具体实现;


本题时给你了确定的y然后求x,可以用二分来求得x;

根据已知得方程可知这个函数时递增得,所以判断无解得条件是:

if(f(0)>y+eps||f(10)<y-eps)


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 牛顿迭代法是一种求解非线性方程组的方法,可以用于MATLAB编程。具体步骤如下: 1. 定义非线性方程组,例如: f1 = @(x) x(1)^2 + x(2)^2 - 1; f2 = @(x) x(1) - x(2)^2; 2. 定义初始值和迭代次数: x = [1;1]; max_iter = 100; 3. 编写牛顿迭代法的主函数: function [x, iter] = newton(f, x, max_iter, tol) % f: 非线性方程组 % x: 初始值 % max_iter: 最大迭代次数 % tol: 收敛精度 iter = ; x = x; while iter < max_iter iter = iter + 1; J = jacobian(f, x); % 计算雅可比矩阵 delta_x = -J\f(x); % 计算增量 x = x + delta_x; % 更新x if norm(delta_x) < tol % 判断是否收敛 break; end end 4. 调用主函数求解非线性方程组: f = @(x) [x(1)^2 + x(2)^2 - 1; x(1) - x(2)^2]; [x, iter] = newton(f, x, max_iter, 1e-6); 其中,f为非线性方程组,x为初始值,max_iter为最大迭代次数,1e-6为收敛精度。函数返回值x为方程组的解,iter为实际迭代次数。 ### 回答2: Matlab是一种强大的数学软件,在解决非线性方程组的问题时,可以使用牛顿迭代法来求解。下面是关于Matlab牛顿迭代法求解非线性方程组的具体介绍。 牛顿迭代法是一种求解非线性方程的方法,其主要思想是利用函数在某一点的一阶或二阶导数信息,来逼近方程的根。具体来说,牛顿迭代法需要从初始猜测点开始迭代,不断使用局部一阶或二阶泰勒展开式来定义下一个猜测点,直至收敛到方程的解。 下面介绍在Matlab中如何利用牛顿迭代法求解非线性方程组。首先需要定义函数的符号表达式,在Matlab中可以使用以下命令进行定义: syms x y z f1 = x^2 + y^2 + z^2 - 25; f2 = x*y + x*z - 8; f3 = y*z - 3; 上述代码定义了三个未知数的非线性方程组,其中f1、f2和f3是每个未知数对应的方程。 接下来需要定义初始的猜测点,以及迭代的最大次数和允许的收敛精度。在Matlab中可以使用以下代码进行定义: x0 = [1;1;1]; % 初始猜测点 n_max = 100; % 迭代最大次数 tol = 1e-6; % 允许的收敛精度 然后,我们需要定义牛顿迭代法的迭代公式。在Matlab中,请使用以下代码进行定义: F = [f1;f2;f3]; J = jacobian(F,[x y z]); % 求解雅可比矩阵 iter = 1; while iter < n_max Jn = double(subs(J,[x y z],x0.')); % 计算雅可比矩阵在当前猜测点的值 Fn = double(subs(F,[x y z],x0.')); % 计算函数向量在当前猜测点的值 xn = x0 - Jn\Fn; % 牛顿迭代公式 if norm(xn - x0) <= tol % 检查收敛精度 break; end x0 = xn; % 记录当前猜测点 iter = iter + 1; % 迭代次数加1 end 在上述代码中,首先使用subs函数将x、y和z替换为当前的猜测点,得到雅可比矩阵和函数值。然后使用牛顿迭代公式得到下一个猜测点,并在下一次迭代时继续执行。如果达到了最大迭代次数或者精度达到了要求,则终止迭代。 最后,我们可以使用以下代码来输出求解结果: if iter < n_max fprintf('Converged to solution after %d iterations:\n', iter); disp(xn); else fprintf('Failed to converge after %d iterations:\n', n_max); end 该代码将输出求解结果,并指示是否成功达到了要求的精度。 总结来说,Matlab可以很容易地实现牛顿迭代法来求解非线性方程组的问题。通过定义函数表达式、初始猜测点、迭代公式以及收敛精度,可以在Matlab中执行快速的非线性方程组求解。 ### 回答3: matlab作为一种常用的数学软件,在求解非线性方程组中有着广泛的应用。其中牛顿迭代法是解决非线性方程组的一种常见方法。 牛顿迭代法是一种逐步逼近的迭代方法,其基本思想是利用函数在某一点的导数(或者偏导数)来构造一个逼近方程,然后根据逼近方程不断迭代,从而达到求解非线性方程组的目的。 在使用matlab求解非线性方程组时,可以利用matlab提供的牛顿迭代法函数进行计算。该函数的输入参数包括一个含有n个元素的初始猜测向量x,一个n×1的函数值向量f(x),一个n×n的雅可比矩阵J(x),以及一些其他的可选参数。其中,雅可比矩阵J(x)是对函数f(x)的一阶导数矩阵。 具体实现时,可以首先定义非线性方程组的函数形式和雅可比矩阵,然后通过调用matlab中的牛顿迭代法函数进行求解。通过不断迭代,可以逐渐得到非线性方程组的解,并可以控制精度和迭代次数等参数。 需要注意的是,在使用牛顿迭代法求解非线性方程组时,函数必须是具有可导性的,否则无法计算函数的导数,从而无法迭代求解。此外,在实际应用中,由于牛顿迭代法存在收敛性的限制和局部最优解的问题,需要对结果进行验证和分析,以确保得到的解在实际应用中具有合理性和可行性。 总的来说,通过在matlab中使用牛顿迭代法求解非线性方程组,可以方便、快捷地得到高精度的解,拓展了非线性方程组求解的方法和途径,并在多个领域的应用中发挥了重要作用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值