| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1469 人关注过本帖
标题:请教有关用牛顿迭代法求平方根的问题
取消只看楼主 加入收藏
CC白痴
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2017-4-15
收藏
 问题点数:0 回复次数:2 
请教有关用牛顿迭代法求平方根的问题
#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
CC白痴
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2017-4-15
收藏
得分:0 
回复 2楼 lmlm1001
啊?那不然该怎么做......原题中要求说y的新旧值之差的绝对值小于0.00001和y的乘积时程序终止啊.....
2017-04-15 18:06
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
快速回复:请教有关用牛顿迭代法求平方根的问题
数据加载中...
 
   



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

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