我正在尝试创建一个定制的pow()函数来比较实际的pow函数的结果,但是它不起作用。当基值为1时,它工作得很好,但在此之后,MyPower函数将返回1作为第一个幂函数,所以它会这样说。
测试1.000000到1电源
测试1.000000到2电源
测试1.000000到3电源
测试1.000000到4电源
2.000000比1是2.000000,结果是1.000000。
2.000000比2是4.000000,结果是2.000000。
2.000000比3是8.000000,结果是4.000000。
2.000000比4是16.000000,结果是8.000000。
它将继续在一个指数的值上,对所有其余的基。我相信错误发生在MyPower()函数中,但我不确定。
#include <stdio.h>
#include <math.h>
double base, x;
int exponent, i, z;
double MyPower(double base, int exponent);
void DoTest(double base, int exponent);
double MyPower(double base, int exponent){
double x = 1;
for(z = 1; z < exponent; z++){
x *= base;
}
return x;
}
int main(void){
int i, j;
for(i = 1; i < 5; i++){
for(j = 1; j < 5; j++){
DoTest(i,j);
}
}
}
void DoTest(double base, int exponent){
double test1 = MyPower(base, exponent);
double pow_result = pow(base, exponent);
if(test1 == pow_result){
printf("Testing %f to the %d power\n", base, exponent);
}
else{
printf("%f to the %d is %f, result is %f\n", base, exponent, pow_result, test1);
}
}发布于 2019-09-24 02:28:45
问题来自循环中的条件.
给定给z的初始值和退出条件的组合使得它的迭代次数比您想做的要少一次:
for(z = 1; z < exponent; z++){
x *= base;
}您需要将其更改为:
for(z = 0; z < exponent; z++){或者:
for(z = 1; z <= exponent; z++){调试程序时的一小条建议
这可能看起来很老套,但是尝试用笔和纸来运行你的算法会帮助你发现这些错误。毫无疑问,当你变得更有经验时,你的意志会变得越来越熟练。欢迎来到StackOverflow!
https://stackoverflow.com/questions/58072205
复制相似问题