当前位置: 代码迷 >> C语言 >> [求助]请高手出手吧!觅高手,快请进!
  详细解决方案

[求助]请高手出手吧!觅高手,快请进!

热度:178   发布时间:2004-12-24 09:28:00.0
[求助]请高手出手吧!觅高手,快请进!
幂问题,求助!

写程序求 Xn(x的n次方)我的程序如下:但不成功为何

#include<stdio.h> power(int x,int n) { int m; if(n==1) return x; for(m=1;m<=n-1;++m) return power(x,m)*x; /*就是power(x,m)乘以x ,不知你看清楚了吗*/ } main() { int x,n; scanf("%d%d",&x,&n) ; printf("This number=%d",power(x,n)); getch(); }

我是用win-tc软件,不是TurboC的,只能正确算n=2的值,当n>2时,其值都与n=2相同,为何?

搜索更多相关的解决方案: int  power  

----------------解决方案--------------------------------------------------------

for(m=1;m<=n-1;++m) return power(x,m)*x;  这里当M=2的时候 就已经返回了啊!


----------------解决方案--------------------------------------------------------

老兄,递归不是这样写滴。递归里面怎么还有for循环呢,我看你还是没有跳出循环的圈子,既想用递归,又忍不住的用了for循环

power(int x,int n) { if(n==1) return x; return x*power(x,n-1);  }


----------------解决方案--------------------------------------------------------

如果想用循环呢,就这样

power(int x,int n) { int i,j; i=1; for(j=0;j<n;j++) i=i*x; return i; }


----------------解决方案--------------------------------------------------------

谢谢各位,“断线风筝”你的解释太经典了,太谢谢你了!


----------------解决方案--------------------------------------------------------
[QUOTE][QUOTE][QUOTE]

power(int x,int n) { if(n==1) return x; return x*power(x,n-1);  }

[/QUOTE]

这样用递归还是不行的,也只能求平方,不能求立方以上的了,也许还要再加上合理的循环吧,另运行时会出错,显示:错误 某一行:非法字符’?(0xa1)在power函数中。

 另

power(int x,int n) { int i,j; i=1; for(j=0;j<n;j++) i=i*x; return i; }[/QUOTE] 是可行的,谢谢!不知第一种方案能否改进!
----------------解决方案--------------------------------------------------------

double POW(double a, int n) { if(n == 0) return 1; else if(n > 0) return (a * POW(a, n-1)); else return (1 / POW(a, -n)); } 我改进了一下你的程序,不知对不对。


----------------解决方案--------------------------------------------------------
没想到大家都这么认真了1
----------------解决方案--------------------------------------------------------
power(int x,int n)
{
if(n==1)
return x;
return x*power(x,n-1);
}
没有错。非法字符是你复制网页弄出来的。
----------------解决方案--------------------------------------------------------
受伤了1
----------------解决方案--------------------------------------------------------
  相关解决方案