| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 627 人关注过本帖
标题:根据牛顿迭代法参照网上一些代码 写了一个可以对任意整数开任意次方的东东 ...
只看楼主 加入收藏
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
结帖率:99.76%
收藏
已结贴  问题点数:100 回复次数:7 
根据牛顿迭代法参照网上一些代码 写了一个可以对任意整数开任意次方的东东 送给大家作为新年礼物
程序代码:

因为不想使用math.h这个头文件  所以自己写了几个函数

#include <stdio.h>
#define zero 0.000001

double mypow(double x,int n)
{
    if(n==0) return 1.0;
    double t=1.0;
    for(;n>0;t*=x,n--);
    return t;
}

int searchroot(double x,int n)
{
    int t=1;
    while(1)
    {
        if (mypow(t,n)-x<=zero && mypow(t+1,n)-x>=zero) return t;
        t++;
    }
    return t;
}

double myfabs(double m,double n)
{
    double t=m-n;
    if(t>0) return t;else return t*(-1);
}

double rooting(double x,int n)
{
    int root=searchroot(x,n);
    double x1=(double)root;
    double x0,f0,f1;
    do
    {
        x0=x1;
        f0=mypow(x0,n)-x;
        f1=n*mypow(x0,n-1);
        x1=x0-f0/f1;
    }while(myfabs(x0,x1)>=zero);
    return x1;
}

int main()
{
    double x=88888888;
    int n=2;
    for(;n<8;printf("对%12.0f进行开%d次方结果是%12.6f\n",x,n-1,rooting(x,n),n++));
    n=2;
    for(;n<8;printf("验证%12.6f的%d次方=%12.6f\n",rooting(x,n),n-1,mypow(rooting(x,n),n),n++));
    return 0;
}



程序代码:
这是样例输出:
对    88888888进行开2次方结果是 9428.090369
对    88888888进行开3次方结果是  446.288632
对    88888888进行开4次方结果是   97.098354
对    88888888进行开5次方结果是   38.883871
对    88888888进行开6次方结果是   21.125545
对    88888888进行开7次方结果是   13.663112
验证 9428.090369的2次方=88888888.000000
验证  446.288632的3次方=88888888.000000
验证   97.098354的4次方=88888888.000000
验证   38.883871的5次方=88888888.000000
验证   21.125545的6次方=88888888.000001
验证   13.663112的7次方=88888888.000000


[ 本帖最后由 wp231957 于 2014-2-3 16:03 编辑 ]
搜索更多相关主题的帖子: 新年礼物 网上 
2014-02-03 15:34
tlliqi
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:204
帖 子:15453
专家分:65956
注 册:2006-4-27
收藏
得分:15 
谢谢 新年快乐噻
2014-02-03 17:01
loveClangage
Rank: 8Rank: 8
来 自:广东云浮
等 级:蝙蝠侠
帖 子:326
专家分:891
注 册:2013-8-23
收藏
得分:15 
谢谢,新年快乐,

编写的程序,不能改变世界,却可以改变自己...
2014-02-04 00:37
韶志
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:斗气大陆
等 级:贵宾
威 望:44
帖 子:2223
专家分:13592
注 册:2013-3-22
收藏
得分:15 
新年快乐!~

三十年河东,三十年河西,莫欺少年穷!
2014-02-04 11:35
zklhp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:china
等 级:贵宾
威 望:254
帖 子:11485
专家分:33241
注 册:2007-7-10
收藏
得分:15 
新年快乐
2014-02-04 11:58
Copain
Rank: 2
等 级:论坛游民
帖 子:10
专家分:69
注 册:2014-1-31
收藏
得分:15 
新年快乐
2014-02-04 16:24
w851777025
Rank: 7Rank: 7Rank: 7
来 自:新疆
等 级:黑侠
威 望:2
帖 子:135
专家分:584
注 册:2014-1-19
收藏
得分:15 
路过,新年快乐
2014-02-04 19:03
大米稀粥客
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:82
专家分:155
注 册:2013-1-8
收藏
得分:15 
新年快乐
2014-02-05 22:39
快速回复:根据牛顿迭代法参照网上一些代码 写了一个可以对任意整数开任意次方的 ...
数据加载中...
 
   



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

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