博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
《C语言及程序设计》实践参考——二分法解方程
阅读量:6623 次
发布时间:2019-06-25

本文共 970 字,大约阅读时间需要 3 分钟。

返回:  

【项目2-二分法解方程】

  二分法是在计算机科学中很重要的一种方法,用于查找产生二分查找算法,还可以用在很多场合。
  可以用二分法解方程。
  对于区间[a,b]上连续不断且f(a)·f(b)<0的函数y=f(x),通过不断地把函数f(x)的零点所在的区间一分为二,使区间的两个端点逐步逼近零点,进而得到零点近似值的方法叫二分法。
  假设要求方程f(x)=0的解,给定精确度ξ。其算法是:

1 确定区间[a,b],验证f(a)·f(b)<02 求区间(a,b)的中点c3 判断(1) 若f(a)·f(c)<0,则令b=c;(2) 若f(c)·f(b)<0,则令a=c.4 判断f(c)是否达到精确度ξ:即若┃f(c)┃
  请按照上面的算法,编程序求解方程f(x)=2x^3-5x^2+3x-6=0,要求精确到0.00001

[参考解答]

#include 
double f(double); //f(x)函数int main(){ double a,b,c; do { printf("请输入一个范围x0 x1:"); scanf("%lf %lf", &a, &b); //尝试输入a和b的值,即确定可能解所在的区间 } while(f(a)*f(b)>=0); //要求这两点上的函数值异号,从而保证[a, b]之间有解 printf("在[%.2f, %.2f]间,方程将有一个根\n",a, b); do { c=(a+b)/2; if(f(a)*f(c)<0) //二分法判断函数值包含0的X取值区间 { b=c; } else { a=c; } } while((f(c)>1e-5)||(f(c)<-1e-5));//判断根c是否在接近函数值0的精确范围内 printf("方程的根为:%.5f\n",c); return 0;}double f(double x){ return(3*x*x*x-5*x*x+3*x-6);}

转载地址:http://nixpo.baihongyu.com/

你可能感兴趣的文章
Oracle绝对值函数
查看>>
mysql 的mgr集群
查看>>
html5播放mp4视频代码
查看>>
032_nginx配置文件安全下载
查看>>
Linux下tomcat修改成的80端口无法访问
查看>>
Kubernetes 集群日志管理 - 每天5分钟玩转 Docker 容器技术(180)
查看>>
redis实现对账(集合比较)功能
查看>>
为了好好看球,学霸们用深度学习重建整个比赛3D全息图
查看>>
浅谈持续集成
查看>>
【ZH奶酪】如何用textgenrnn处理中文
查看>>
CentOS双机中Docker下安装Mysql并配置互为主从模式
查看>>
OkHttp3源码详解(六) Okhttp任务队列工作原理
查看>>
这样做,轻松在Word中使用MathType
查看>>
VS Code非英语版本连接TFS错误解决方案
查看>>
angular5中使用jsonp请求页面
查看>>
sql in not in 案例用 exists not exists 代替
查看>>
使用newtonjson解决Json日期格式问题
查看>>
WEB前端资源代码:学习篇
查看>>
Nginx安装及配置详解【转】
查看>>
vue2.0 :style :class样式设置
查看>>