函数模板
<valarray>

std::pow

template<class T> valarray<T> pow (const valarray<T>& x, const valarray<T>& y);template<class T> valarray<T> pow (const valarray<T>& x, const T& y);template<class T> valarray<T> pow (const T& x, const valarray<T>& y);
计算 valarray 元素的幂
返回一个valarray,其中包含对所有元素执行幂运算的结果,顺序与原序列相同。计算结果为 xy 次方 (xy)。

该函数对 xy 中的每个元素调用一次(未加限定的)pow;如果其中一个是单个 T 值,则该值将用于所有调用。

此函数重载了 cmath 的 pow

参数

x
valarray 或具有幂运算基数的元素。
y
valarray 或具有幂运算指数的元素。
如果两个参数都是 valarray 对象且它们的大小不匹配,则行为未定义。

返回值

一个 valarray 对象,其中包含 xy 次方的值。

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
// pow valarray example
#include <iostream>     // std::cout
#include <cstddef>      // std::size_t
#include <cmath>        // std::pow
#include <valarray>     // std::valarray, std::pow

int main ()
{
  std::valarray<double> val (5);
  std::valarray<double> results;

  for (int i=0; i<5; ++i) val[i]=i+1;
  std::cout << "val:";
  for (std::size_t i=0; i<val.size(); ++i) std::cout << ' ' << val[i];
  std::cout << '\n';

  results = std::pow (val,val);
  std::cout << "val^val:";
  for (std::size_t i=0; i<results.size(); ++i) std::cout << ' ' << results[i];
  std::cout << '\n';

  results = std::pow (val,2.0);
  std::cout << "val^2:";
  for (std::size_t i=0; i<results.size(); ++i) std::cout << ' ' << results[i];
  std::cout << '\n';

  results = std::pow (2.0,val);
  std::cout << "2^val:";
  for (std::size_t i=0; i<results.size(); ++i) std::cout << ' ' << results[i];
  std::cout << '\n';

  return 0;
}

输出

val: 1 2 3 4 5
val^val: 1 4 27 256 3125
val^2: 1 4 9 16 25
2^val: 2 4 8 16 32


另见