命名空间
变体
操作

std::acos(std::valarray)

来自 cppreference.cn
< cpp‎ | numeric‎ | valarray
 
 
 
 
定义于头文件 <valarray>
template< class T >
valarray<T> acos( const valarray<T>& va );

对于 va 中的每个元素,计算该元素值的反余弦。

内容

[编辑] 参数

va - 应用运算的值数组

[编辑] 返回值

包含 va 中值的反余弦值的值数组。

[编辑] 注意

非限定函数 (acos) 用于执行计算。如果此函数不可用,则由于实参依赖查找,将使用 std::acos

该函数可以使用与 std::valarray 不同的返回类型来实现。在这种情况下,替换类型具有以下属性

[编辑] 可能的实现

template<class T>
valarray<T> acos(const valarray<T>& va)
{
    valarray<T> other = va;
    for (T& i : other)
        i = acos(i);
 
    return other; // proxy object may be returned
}

[编辑] 示例

#include <cmath>
#include <iostream>
#include <numbers>
#include <valarray>
 
int main()
{
    // take common x-values from unit circle
    const double s32 = std::sqrt(3.0) / 2.0;
    const double s22 = std::sqrt(2.0) / 2.0;
    std::valarray<double> v1 = {-1.0, -s32, -s22, -0.5, 0.0, 0.5, s22, s32, 1.0};
    std::valarray<double> v2 = std::acos(v1) * 180.0 / std::numbers::pi;
 
    for (double n : v2)
        std::cout << n << "° ";
    std::cout << '\n';
}

输出

180° 150° 135° 120° 90° 60° 45° 30° 0°

[编辑] 参见

将函数 std::asin 应用于 valarray 的每个元素
(函数模板) [编辑]
将函数 std::atan 应用于 valarray 的每个元素
(函数模板) [编辑]
将函数 std::atan2 应用于 valarray 和一个值
(函数模板) [编辑]
将函数 std::cos 应用于 valarray 的每个元素
(函数模板) [编辑]
(C++11)(C++11)
计算反余弦 (arccos(x))
(函数) [编辑]
计算复数的反余弦 (arccos(z))
(函数模板) [编辑]