24小时热门版块排行榜    

查看: 572  |  回复: 2

elflegolas

铁虫 (初入文坛)

[求助] 函数递归调用求幂,为什么float可以double不行?

很简单的程序啦,子函数递归调用求幂:
#include
float power(float x,int m)
{
    if(m==1)
        return x;
    else
        return  x*power(x,m-1);
}
int main()
{
    float a;
        int b;
    printf("please input two number:\n";
    scanf("%f%d",&a,&b);
    printf("the number is %.2f\n",power(a,b));
        return 0;
}
用的是VC++6.0,程序中下划线的两处如果将float改成double程序就不能得到正确结果,想不通什么原因。求助。
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

fdesheng

木虫 (正式写手)

【答案】应助回帖

感谢参与,应助指数 +1
#include
double power(double x,int m)
{
    if(m==1)
        return x;
    else
        return  x*power(x,m-1);
}
int main()
{
    double a;
    int b;
    printf("please input two number:\n";
    scanf("%lf%d",&a,&b);
    printf("the number is %.2f\n",power(a,b));
        return 0;
}
这样可以我试着,scanf的那儿稍微修改了一下。
2楼2012-09-06 21:59:50
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
elflegolas: 金币+5, ★★★★★最佳答案, 谢谢,谢谢,我基础知识太薄弱了 2012-09-07 08:37:23
xzhdty: 金币+2, 专家考核, 谢谢骠骑将军 2012-09-07 22:49:13
仔细看书,float和double虽然都是浮点数,但是printf和scanf的时候需要不同的格式
float对应%f,double对应%lf
所以你的程序从float改为double后只需要添加2个小写字母L(l)即可
CODE:
#include
double power(double x,int m)
{
    if(m==1)
        return x;
    else
        return  x*power(x,m-1);
}
int main()
{
    double a;
    int b;
    printf("please input two number:\n");
    scanf("%lf%d",&a,&b);
    printf("the number is %.2lf\n",power(a,b));
    return 0;
}

matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
3楼2012-09-06 23:45:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 elflegolas 的主题更新
信息提示
请填处理意见