Итак, я пытаюсь реализовать свою собственную функцию pow.Чтобы упростить ситуацию, мне разрешено использовать тип int для показателя степени.Так что код работает ... в основном.У меня есть файл с именем xmath.c, в котором я реализую свою функцию pow и другой test.c для проверки ограничений.Единственный случай, когда он не работает, это pow(-111, INT_MAX)
.Как я могу улучшить свой код?Также скажите мне, если я должен опубликовать код test.c также.xfabs
- это еще одна функция, которую мне пришлось реализовать самостоятельно вместо использования fabs
.
Забыл включить xfabs в мое сообщение:
#define xfabs(x) (((x) > 0) ? (x) : (-(x)))
#include <stdio.h>
#include <errno.h>
#include <math.h>
#include <float.h>
#include "xmath.h"
double xpow(double x, int y)
{
errno = 0;
double product = 1;
double prod = 1;
int i;
if (y == 0) {
return 1.0;
} else if (x == 0 && y < 0) {
errno = EDOM;
return 0.0;
}
if (xfabs(x) >= 1) {
if (y > 0) {
for (i = 0; i < y; i++) {
if (xfabs(product) > DBL_MAX / xfabs(x)) {
errno = ERANGE;
return HUGE_VAL;
}
product *= x;
}
return product;
} else if (y < 0) {
for (i = 0; i > y; i--) {
if (xfabs(product) < DBL_MIN / xfabs(x)) {
errno = ERANGE;
return -0.0;
}
product *= 1 / x;
}
return product;
}
} else if (xfabs(x) < 1) {
if (y > 0) {
for (i = 0; i < y; i++) {
if (xfabs(prod) < DBL_MIN / xfabs(x)) {
errno = ERANGE;
return +0.0;
}
prod *= x;
}
return prod;
} else if (y < 0) {
for (i = 0; i > y; i--) {
if (xfabs(prod) < DBL_MAX / xfabs(x)) {
errno = ERANGE;
return -HUGE_VAL;
}
prod *= 1 / x;
}
return prod;
}
}
}
Вот тестовая функция.Также я создаю объектный файл для xmath.c, который я использую в test.c:
#include <stdio.h>
#include <float.h>
#include <math.h>
#include <errno.h>
#include <limits.h>
#include "xmath.h"
void xpow_tests(void)
{
printf("XPOW TESTS (SUCCESS == 1 / FAILURE == 0)\n");
printf("=================================================\n");
printf("Test (xpow(2, 5)): \t\t%i\t", xpow(2, 5) == pow(2, 5));
xpow(2, 5);
printf("errno: %i\n", errno);
printf("Test (xpow(-2, -4)): \t\t%i\t", xpow(-2, -4) == pow(-2, -4));
xpow(-2, -4);
printf("errno: %i\n", errno);
printf("Test (xpow(1, 15)): \t\t%i\t", xpow(1, 15) == pow(1, 15));
xpow(1, 15);
printf("errno: %i\n", errno);
printf("Test (xpow(-4, 414)): \t\t%i\t", xpow(-4, 414) == pow(-4, 414));
xpow(-4, 414);
printf("errno: %i\n", errno);
printf("Test (xpow(-5, 303)): \t\t%i\t", xpow(-5, 303) == pow(-5, 303));
xpow(-5, 303);
printf("errno: %i\n", errno);
printf("Test (xpow(0, -3)): \t\t%i\t", xpow(0, -3) == 0);
xpow(0, -3);
printf("errno: %i\n", errno);
printf("Test (xpow(1.0e-10, 100)): \t%i\t", xpow(1.0e-10, 100) == pow(1.0e-10, 100));
xpow(1.0e-10, 100);
printf("errno: %i\n", errno);
printf("Test (xpow(-1.0e-10, 101)): \t%i\t", xpow(-1.0e-10, 101) == pow(-1.0e-10, 101));
xpow(-1.0e-10, 101);
printf("errno: %i\n", errno);
printf("Test (xpow(-111, INT_MAX)): \t%i\t", xpow(-111, INT_MAX) == pow(-111, INT_MAX));
xpow(-111, INT_MAX);
printf("errno: %i\n", errno);
printf("Test (xpow(-111, INT_MAX-1)): \t%i\t", xpow(-111, INT_MAX-1) == pow(-111, INT_MAX-1));
xpow(-111, INT_MAX-1);
printf("errno: %i\n", errno);
printf("Test (xpow(-111, -INT_MAX)): \t%i\t", xpow(-111, -INT_MAX) == pow(-111, -INT_MAX));
xpow(-111, -INT_MAX);
printf("errno: %i\n", errno);
printf("Test (xpow(-111, -INT_MAX+1)): \t%i\t", xpow(-111, -INT_MAX+1) == pow(-111, -INT_MAX+1));
xpow(-111, -INT_MAX+1);
printf("errno: %i\n", errno);
printf("=================================================\n");
printf("errno (EDOM: %i / ERANGE: %i)\n\n", EDOM, ERANGE);
}
int main(void)
{
xpow_tests();
return 0;
}