迭代求方程的根c++

迭代求方程的根c++

题目

求x³-x-1=0的根

迭代求根方法

  1. 将方程变形,求出根的收敛表达示g(x),即x=∛(x+1)。而不能变成x=x³-1,因为这个x的表达式是发散的。
  2. 选一个方程的近似根2,赋给变量x0。
  3. 将x0的值保存于变量x1,然后计算g(x1),并将结果存于变量x0;
  4. 当x0与x1的差的绝对值还大于指定的精度要求时,重复步骤2、3的计算。

代码

cpp 复制代码
#include<stdio.h>
#include<math.h>
typedef double(*fpt)(double);//函数指针 
int rootX(fpt g,double initRoot,double precision,double *root){
	double x0=initRoot,x1=0;
	int n=0;//迭代次数
	do{
		printf("x%d=%.5f\n",n,x0);
		x1=x0;
		x0=g(x1);
		n++;
	} while(fabs(x0-x1)>= precision);
	*root=x0;
	printf("x%d=%.5f\n",n,x0);
	return n;
}
double f(double x){
	return pow(x+1,1.0/3.0);
}
int main(){
	double x;
	int m=rootX(f,2,0.000005,&x);
	printf("迭代%d次,根为%.5f\n",m,x);
}

说明

pow 函数

  • base 是底数,可以是任意浮点数。
  • exponent 是指数,也可以是任意浮点数。
  • 返回值是 base 的 exponent 次幂,类型为 double。
cpp 复制代码
double pow(double base, double exponent);
相关推荐
枕星而眠13 小时前
C++面向对象核心:类间关系与继承深度解析
运维·开发语言·c++·后端
MegaDataFlowers13 小时前
543.二叉树的直径
算法
Kurisu57513 小时前
深度拆解:从 CPU 乱序执行到内存屏障,无锁编程的底层防线
算法
GIOTTO情13 小时前
智能舆情处置系统技术方案:基于NLP语义算法的全链路风险处置落地
人工智能·算法·自然语言处理
郝学胜_神的一滴13 小时前
力扣 144:二叉树前序遍历的优雅实现
数据结构·算法
超梦dasgg13 小时前
Dijkstra(迪杰斯特拉)算法详解
java·数据结构·算法
比企谷八幡13 小时前
数据库 Page 内部是什么样:Page Header、Slot 和 Line Pointer
数据库·c++·postgresql·数据库架构
阿文的代码库13 小时前
如何解决缺少特定算法思维的问题?
算法
yuan1999713 小时前
基于人工神经网络(ANN)的独立成分分析(ICA)算法
算法
代码地平线13 小时前
C++ 入门篇类和对象·上篇:从本质深剖类与对象与C++基本用法
c语言·开发语言·数据结构·c++·笔记·算法