C# 一元多次方程求解

private double FindRoot(double a, double b, double c, double d, double target)

{

double x0 = 1.0; // 初始猜测值

double epsilon = 0.0001; // 迭代精度

double f(double t) => a * t * t * t + b * t * t + c * t + d - target; // 定义方程

double df(double t) => 3 * a * t * t + 2 * b * t + c; // 方程的导数

double x1 = x0 - f(x0) / df(x0); // 牛顿迭代公式

while (Math.Abs(x1 - x0) > epsilon)

{

x0 = x1;

x1 = x0 - f(x0) / df(x0);

}

return x1;

}

相关推荐
ValhallaCoder4 小时前
hot100-栈
数据结构·python·算法·
WW_千谷山4_sch8 小时前
洛谷B3688:[语言月赛202212]旋转排列(新解法:deque双端队列)
数据结构·c++·算法
Zachery Pole8 小时前
【代码随想录】二叉树
算法
漂流瓶jz8 小时前
UVA-11214 守卫棋盘 题解答案代码 算法竞赛入门经典第二版
c++·算法·dfs·aoapc·算法竞赛入门经典·迭代加深搜索·八皇后
浮生09198 小时前
DHUOJ 基础 88 89 90
算法
v_for_van9 小时前
力扣刷题记录7(无算法背景,纯C语言)
c语言·算法·leetcode
先做个垃圾出来………9 小时前
3640. 三段式数组 II
数据结构·算法
Never_Satisfied10 小时前
在c#中,使用windows自带功能将文件夹打包为ZIP
开发语言·windows·c#
tankeven10 小时前
HJ93 数组分组
c++·算法
Σίσυφος190010 小时前
LM 在 PnP(EPnP / P3P)的应用
算法