C语言程序设计,用迭代法求根号a,公式为Xn+1=(1/2)(Xn+a/Xn)

要求前后两次求出的X的差的绝对值小于10^-5。Xn初值可为a/2。用循环设计。

这很容易的啊

#include <stdio.h>
#include <math.h>
double funcx( double x , double a) 
{
double y;
if ( x==0 )
return 1;
y=0.5*(x+ a/x ) ;//改此函数可以求各种迭代
return y;
}
int main()
{
double x1,x2,e=1e-5 ,a;
printf("input a : ");
scanf("%lf", &a );
x2=1;
do {
x1=x2;
x2=funcx( x1, a );
} while( fabs(x2-x1) > e );
printf("%g\n", x2 );
return 0;
}

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2017-11-27
# include <stdio.h>
# include <math.h>
main()
{
double m,n=1.0,a;

printf("请输入a:");
scanf("%lf",&a);
do
{
m=n;
n= (m + a/m) / 2;
}
while(fabs(n-m)>1e-5);
printf("结果为:%7.5f\n",n);
}本回答被提问者采纳
第2个回答  2018-04-04

# include <stdio.h>

# include <math.h>

main()

{

double m,n=1.0,a;

printf("请输入a:");

scanf("%lf",&a);

do

{

m=n;

n= (m + a/m) / 2;

}

while(fabs(n-m)>1e-5);

printf("结果为:%7.5f\n",n);

}。

最佳答案由提问者推荐

#include<stdio.h>

#include<math.h>

void main()

{

float a,x0,x1;

scanf("%f",&a);

x0=a/2;

x1=(x0+a/x0)/2;

do{

x0=x1;

x1=(x0+a/x0)/2;

}while(fabs(x0-x1)>1.0e-5);

printf("%.5f",x1);

}。

本回答被网友采纳

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网