c语言割线法求方程跟,分别用牛顿法和割线法求解方程 x^3-6x^2+9x-2=0在区间[3,4]上的近似根.要求满足精度|x*-xk|...

%

clc; clear all;

global fnq dfnq

fnq = @(x) x^3 - 6*x^2 + 9*x - 2;

dfnq = @(x) 3*x^2 - 12*x + 9;

tol = (1/2)*10^-4;x0 = 3.5;gmax = 1e3;x01 = 3;x02 = 4;[k,xk,yk,piancha]=newtonqx(x0,tol,gmax);

fprintf('\n牛顿法:%.5f\n',xk);

[k,xk,yk,piancha]=gexian(x01,x02,tol,gmax);

fprintf('\n割线法:%.5f\n',xk);% 牛顿法

function [k,xk,yk,piancha]=newtonqx(x0,tol,gmax)

global fnq dfnqx(1)=x0;for i=1:gmax

x(i+1)=x(i)-fnq(x(i))/(dfnq(x(i)+eps));

piancha=abs(x(i+1)-x(i));i=i+1;

xk=x(i);yk=fnq(x(i));

[(i-1) xk yk piancha];

if(pianchagmaxdisp('超过最大迭代次数')k=i-1;xk=x(i);yk=fnq(x(i));

[i-1 xk yk piancha];return;end% 割线法function [k,xk,yk,piancha]=gexian(x01,x02,tol,gmax)

global fnq dfnq

x(1)=x01;x(2)=x02;

for i=2:gmax

u(i)=fnq(x(i))*(x(i)-x(i-1));

v(i)=fnq(x(i))-fnq(x(i-1));

x(i+1)=x(i)-u(i)/(v(i));

piancha=abs(x(i+1)-x(i));i=i+1;xk=x(i);yk=fnq(x(i));

if(piancha>

解析看不懂?求助智能家教解答查看解答

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值