标题:[求助]请高手出手吧!觅高手,快请进!
只看楼主
lmr
Rank: 1
等 级:新手上路
帖 子:86
专家分:0
注 册:2004-12-9
 问题点数:0 回复次数:13 
[求助]请高手出手吧!觅高手,快请进!
幂问题,求助!

写程序求 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 
2004-12-24 09:28
aniude
Rank: 2
等 级:新手上路
威 望:3
帖 子:231
专家分:0
注 册:2004-11-3
得分:0 

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


2004-12-24 09:43
断线风筝
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2004-5-20
得分:0 

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

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

2004-12-24 10:17
断线风筝
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2004-5-20
得分:0 

如果想用循环呢,就这样

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

2004-12-24 10:20
lmr
Rank: 1
等 级:新手上路
帖 子:86
专家分:0
注 册:2004-12-9
得分:0 

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

2004-12-24 10:53
lmr
Rank: 1
等 级:新手上路
帖 子:86
专家分:0
注 册:2004-12-9
得分:0 
[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] 是可行的,谢谢!不知第一种方案能否改进!
2004-12-24 11:05
young
Rank: 3Rank: 3
等 级:论坛游侠
威 望:2
帖 子:223
专家分:160
注 册:2004-9-5
得分:0 

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)); } 我改进了一下你的程序,不知对不对。


如果你爱C语言,请你爱指针; 如果你爱指针,请你爱指针的指针;
2004-12-24 13:16
时空之蕊
Rank: 2
等 级:新手上路
威 望:3
帖 子:691
专家分:0
注 册:2004-10-31
得分:0 
没想到大家都这么认真了1

我渴望掌控时空的核心——用最先进的技术,打造无比美丽的世界!
2004-12-25 11:56
mingyue
Rank: 1
等 级:新手上路
帖 子:60
专家分:0
注 册:2004-5-13
得分:0 
power(int x,int n)
{
if(n==1)
return x;
return x*power(x,n-1);
}
没有错。非法字符是你复制网页弄出来的。

2004-12-25 19:50
断线风筝
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2004-5-20
得分:0 
受伤了1
2004-12-27 10:05



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




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

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