用二分法求方程x^3-x-1=0在区间[1,1.5]内的一个近似解 用C语言编程 跪求!!!各位大虾

用二分法求方程x^3-x-1=0在区间[1,1.5]内的一个近似解用C语言编程跪求!!!各位大虾画出流程图谢谢各位大虾了帮忙!!急死了... 用二分法求方程x^3-x-1=0在区间[1,1.5]内的一个近似解 用C语言编程 跪求!!!各位大虾 画出流程图 谢谢各位大虾了 帮忙!!急死了 展开
 我来答
鷹弈
2010-10-18 · TA获得超过5194个赞
知道大有可为答主
回答量:1257
采纳率:0%
帮助的人:612万
展开全部
二分法的基本思路是:任意两个点x1和x2,判断区间(x1,x2)内有无一个实根,如果f(x1)与f(x2)符号相反,则说明有一实根。接着取(x1,x2)的中点x,检查f(x)和f(x2)是否同号,如果不同号,说明实根在(x,x2)之间,如果同号,在比较(x1,x),这样就将范围缩小一半,然后按上述方法不断的递归调用,直到区间相当小(找出根为止)!

代码如下(已调试):

#include "math.h"
main()
{
float x,x1,x2;
float F(float x,float x1,float x2);
printf("请输入区间[x1,x2]\n");
scanf("%f%f",&x1,&x2);
printf("x=%f\n",F(x,x1,x2));

}
float F(float x,float x1,float x2)
{
float f,f1,f2;
do

{
f1=pow(x1,3)-x1-1.0;
f2=pow(x2,3)-x2-1.0;
}while(f1*f2>0); //确保输入的x1,x2使得f1,f2符号相反
do
{
x=(x1+x2)/2; //求x1,x2的中点
f=pow(x,3)-x-1.0;
if(f1*f>0) //当f与f1符号相同时
{x1=x;f1=f;}
else if(f2*f>0) //当f与f2符号相同时
{x2=x;f2=f;}
}while(fabs(f)>1e-6); //判断条件fabs(f)>1e-6的意思是f的值非常0
return x;
}

输入:1 1.5
则输出:x=1.324718
最爱qfzhl
2010-10-18
知道答主
回答量:15
采纳率:0%
帮助的人:19.2万
展开全部
#include<stdio.h>
#include<math.h>
double f(double x)
{
return pow(x,3)-x-1;
}
void main()
{
int k=0;double a,b,limit;
printf("\nplease input the 区间:");
scanf(""%lf %lf",&a,&b);
printf("\nplease input the 解的精确程度:");
scanf("%lf",&limit);
if(f(a)*f(b)>0)
printf("\n 无法用二分法求解");
else
{
while((b-a)>limit)
{
if((f(a+b)/2)*f(b)<0)//异号
a=(a+b)/2;
else //同号
b=(a+b)/2;
k++;
}

print("\n经历了%d次二分法求解,解为:%lf\n",k,(a+b)/2);
}
}

那个啥 流程图??????????我就不画了啊
看懂算法的话 就很简单了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式