c语言 用迭代法求解 5

键盘输入一个实数a,输出它的立方根。请自行设计算法编写程序,不允许调用pow函数。程序用3_18.c命名并上交。【提示】假设a的立方根为x,则x3=a,问题转化求一元高次... 键盘输入一个实数a,输出它的立方根。请自行设计算法编写程序,不允许调用pow函数。程序用3_18.c命名并上交。
【提示】
假设a的立方根为x,则x3=a,问题转化求一元高次方程x3-a=0的解
展开
 我来答
pencilpine
2011-04-24 · TA获得超过661个赞
知道小有建树答主
回答量:381
采纳率:0%
帮助的人:429万
展开全部
include<stdio.h>
#include<math.h>

int main()
{
double a;
double x2=0,x1=1.0;
printf("请输入被开方数:");
scanf("%lf",&a);
for(x1=1.0;fabs(x2-x1)>1e-10;)
{
x1=x2;
x2=(2*x1+a/(x1*x1*3.0));
}
printf("结果为:%f",x2);
return 0;
}
嘿_行
2011-04-16 · TA获得超过158个赞
知道答主
回答量:190
采纳率:0%
帮助的人:152万
展开全部
#include<stdio.h>
#include<math.h>

int main()
{
double a;
double temp,xk2,xk1=0;
printf("请输入一实数:");
scanf("%lf",&a);
do{
xk2=(2*xk1+a/(xk1*xk1))/3.0; //Newton 法
temp=xk1;
xk1=xk2;
} while(fabs(xk2-temp)<1e-6)
return 0;
}
追问
怎么运行结果不对呢
追答
刚刚少了个分号

#include
#include

int main()
{
double a;
double temp,xk2,xk1=1.0;
printf("请输入一实数:");
scanf("%lf",&a);
do{
xk2=(2*xk1+a/(xk1*xk1))/3.0; //Newton 法
temp=xk1;
xk1=xk2;
}while(fabs(xk2-temp)<1e-6);
printf("所得结果:%f",xk2);
return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
porker2008
2011-04-16 · TA获得超过1.4万个赞
知道大有可为答主
回答量:7066
采纳率:62%
帮助的人:1.1亿
展开全部
#include <stdio.h>
#include <math.h>

double fun(double a, double x)
{
return x*x*x-a;
}

int main()
{
double a,i,j;
scanf("%lf",&a);
if(a==0) printf("%f\n",0.0);
else if(a>0)
{
i=0;j=1;
while(fun(a,j)<0)
{i=j;j*=2;}
}
else if(a<0)
{
i=-1;j=0;
while(fun(a,i)>0)
{j=i;i*=2;}
}
if(a!=0)
{
while(fabs(fun(a,(i+j)/2))>0.00001) // 二分法
{
if(fun(a,(i+j)/2)>0) j = (i+j)/2;
else if(fun(a,(i+j)/2)<0) i = (i+j)/2;
else
{
i = j = (i+j)/2;
break;
}
}
i = (i+j)/2;
printf("%f\n",i);
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式