#include <stdio.h>
#include <math.h>
C言語
1 2#include <stdio.h> 3#include <math.h> 4 5double g(double x) 6{ 7 return exp(-x)-sin(x); 8} 9double dg(double x) { 10 return -exp(-x)-cos(x); 11} 12 13double newton2(double xn) 14{ 15 int i = 0; 16 double xo; 17 18 while (fabs(xn-xo)>1e-10){ 19 xo = xn; 20 xn = -1 * g(xo) / dg(xo) +xo; 21 i++; 22 }; 23 printf("result:%lf,試行回数:%d\n",xn,i); 24} 25int main() 26{ 27 28 printf("ニュートン法\n"); 29 newton2(2.0); 30 31 return 0; 32}
結果
ニュートン法
result:25.132741,試行回数:8
が出てきます。
実際、出力したいのは、result:0.588533です。
どこが間違っているのか教えていただければ幸いです。
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2022/05/18 02:09 編集
2022/05/18 05:20