标题:请教有关用牛顿迭代法求平方根的问题
只看楼主
CC白痴
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2017-4-15
 问题点数:0 回复次数:4 
请教有关用牛顿迭代法求平方根的问题
#include <stdio.h>
#include <math.h>


int main(void)

{
    double x, average;
    double y =  1.0f;
    double judge = 0.00001f;


    printf("Enter a positive number: ");
    scanf("%lf", &x);


    do {
        average = (y + (x / y))/2;
        y = average;
    } while (fabs(y - average) > judge * y);


    printf("Square_root: %lf", y);

    return 0;
}

我觉得应该是循环能力算法出了问题,但是不知道该怎么改?求问各路大神....
搜索更多相关主题的帖子: positive average include double number 
2017-04-15 11:36
lmlm1001
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:4
帖 子:107
专家分:550
注 册:2015-3-1
得分:0 
judge 别乘以y
2017-04-15 13:35
CC白痴
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2017-4-15
得分:0 
回复 2楼 lmlm1001
啊?那不然该怎么做......原题中要求说y的新旧值之差的绝对值小于0.00001和y的乘积时程序终止啊.....
2017-04-15 18:06
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:0 
你代码不是抄的吧
double y =  1.0f;
double judge = 0.00001f;

你的算法写完了,要回头看一眼
do {
    average = (y + x/y)/2;
    y = average;
} while (fabs(y - average) > judge * y);

程序代码:
#include <stdio.h>
#include <math.h>

int main( void )
{
    double x;
    double y =  1.0;
    double judge = 0.00001;

    printf( "Enter a positive number: " );
    scanf( "%lf", &x );

    while( fabs(y-(y+x/y)/2) > judge*y )
        y = (y+x/y)/2;

    printf( "Square_root: %lf", y );

    return 0;
}

2017-04-17 09:05
CC白痴
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2017-4-15
得分:0 
回复 4楼 rjsp
是我自己写的。当时循环那里一直不通,后来想明白了。下面是我改了之后的。


#include <stdio.h>
#include <math.h>

int main(void)

{
    double x, average, temp;
    double y =  1.0f;
;


    printf("Enter a positive number: ");
    scanf("%lf", &x);


    do {
        average = (y + (x / y))/2;
        temp = fabs(y - average);
        y = average;
    } while (temp > 0.00001 * y);


    printf("Square_root: %lf", y);

    return 0;
}
2017-04-17 19:14



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-476137-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.058224 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved