名稱空間
變體
操作

std::acos(std::valarray)

來自 cppreference.com
< 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))
(函式模板) [編輯]