sqrt () возвращает INF - PullRequest
       60

sqrt () возвращает INF

3 голосов
/ 01 февраля 2011

Привет! Я пытаюсь выполнить некоторые вычисления с длинными значениями типа double и получаю INF из функции sqrt ().

Код:

#include <math.h>
#include <stdio.h>

int main()
{
    long double bigNUMBER;
    long double p1,p2,p3;
    long double p4;

    p1 = 4.769547e+155;
    p2 = 1.012994e+170;
    p3 = 1.714812e+169;

    p4 = p1*p1 + p2*p2 + p3*p3;

    bigNUMBER = sqrt(p4);

    printf("product: %Lf\n\n", p4); // 1055562645989439942507809393771156765931135...

    printf("\n result %Lf\n\n", bigNUMBER); // INF

    return 0;
}

Спасибо!

Ответы [ 2 ]

8 голосов
/ 01 февраля 2011

sqrt принимает и возвращает double. Когда вы звоните, ваш long double будет преобразован в double, который не может хранить такое большое число и, таким образом, получит значение бесконечности.

Используйте sqrtl, который принимает и возвращает long double.

2 голосов
/ 01 февраля 2011

sqrt вернет INFINITY, когда аргумент будет INFINITY; e.g.:

#include <stdio.h>
#include <math.h>
int main()
{
  printf("%g %g\n", INFINITY, sqrt(INFINITY));
  return 0;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...