acos, acosf, acosl
Вычисляет арккосинус.
double acos(
double x
);
float acos(
float x
); // C++ only
long double acos(
long double x
); // C++ only
float acosf(
float x
);
long double acosl(
long double x
);
Параметры
- x
Значение между -1 и 1, для которого нужно вычислить арккосинус.
Возвращаемое значение
Функция acos возвращает арккосинус x в диапазоне от 0 до π радиан.
По умолчанию, если x меньше –1 или больше 1, то acos возвращает неопределенное значение.
Ввод |
Исключение SEH |
Исключение Matherr |
---|---|---|
± ∞ |
INVALID |
_DOMAIN |
± QNAN,IND |
Нет |
_DOMAIN |
|x|>1 |
INVALID |
_DOMAIN |
Заметки
Поскольку C++ допускает перегрузки, можно вызывать перегрузки acos, принимающие и возвращающие типы float и long double. В программе C acos всегда принимает и возвращает double.
Требования
Подпрограмма |
Обязательный заголовок |
Необязательные заголовки |
---|---|---|
acos, acosf, acosl |
<math.h> |
<errno.h> |
Пример
Эта программа запрашивает значения в диапазоне от -1 до 1. Входные значения вне этого диапазона вызывают сообщения об ошибке _DOMAIN. Если введено допустимое значение, то программа выводит арксинус и арккосинус от этого значения.
// crt_asincos.c
// arguments: 0
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
int main( int ac, char* av[] )
{
double x,
y;
errno_t err;
// argument checking
if (ac != 2)
{
fprintf_s( stderr, "Usage: %s <number between -1 and 1>\n",
av[0]);
return 1;
}
// Convert argument into a double value
if ((err = sscanf_s( av[1], "%lf", &x )) != 1)
{
fprintf_s( stderr, "Error converting argument into ",
"double value.\n");
return 1;
}
// Arcsine of X
y = asin( x );
printf_s( "Arcsine of %f = %f\n", x, y );
// Arccosine of X
y = acos( x );
printf_s( "Arccosine of %f = %f\n", x, y );
}
Эквивалент в .NET Framework
См. также
Ссылки
Поддержка чисел с плавающей запятой
atan, atanf, atanl, atan2, atan2f, atan2l
cos, cosf, cosl, cosh, coshf, coshl